diff --git a/examples/0205-generics-generic-method-dot-call.sx b/examples/0205-generics-generic-method-dot-call.sx index 07561e4..bdae350 100644 --- a/examples/0205-generics-generic-method-dot-call.sx +++ b/examples/0205-generics-generic-method-dot-call.sx @@ -16,7 +16,7 @@ Holder :: struct { } main :: () -> s32 { - h : *Holder = xx malloc(size_of(Holder)); + h : *Holder = xx libc_malloc(size_of(Holder)); h.n = 7; print("plain: {}\n", h.plain()); diff --git a/examples/0604-comptime-typed-store-widths.sx b/examples/0604-comptime-typed-store-widths.sx index 12ee5b3..b75453b 100644 --- a/examples/0604-comptime-typed-store-widths.sx +++ b/examples/0604-comptime-typed-store-widths.sx @@ -39,112 +39,112 @@ sum_bytes :: (buf: [*]u8) -> s64 { } run_u8 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *u8 = xx @buf[TARGET]; p.* = 0x42; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_u16 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *u16 = xx @buf[TARGET]; p.* = 0x0102; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_u32 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *u32 = xx @buf[TARGET]; p.* = 0x01020304; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_u64 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *u64 = xx @buf[TARGET]; p.* = 0x0102030405060708; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_s8 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *s8 = xx @buf[TARGET]; p.* = 0x42; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_s16 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *s16 = xx @buf[TARGET]; p.* = 0x0102; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_s32 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *s32 = xx @buf[TARGET]; p.* = 0x01020304; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_s64 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *s64 = xx @buf[TARGET]; p.* = 0x0102030405060708; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_bool :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *bool = xx @buf[TARGET]; p.* = true; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_f32 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *f32 = xx @buf[TARGET]; p.* = 1.0; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } run_f64 :: () -> s64 { - buf : [*]u8 = xx malloc(BUF_SIZE); + buf : [*]u8 = xx libc_malloc(BUF_SIZE); fill(buf); p : *f64 = xx @buf[TARGET]; p.* = 1.0; s := sum_bytes(buf); - free(xx buf); + libc_free(xx buf); s } diff --git a/examples/0804-memory-xx-target-in-field-assign.sx b/examples/0804-memory-xx-target-in-field-assign.sx index d7a920a..e681887 100644 --- a/examples/0804-memory-xx-target-in-field-assign.sx +++ b/examples/0804-memory-xx-target-in-field-assign.sx @@ -28,7 +28,7 @@ begin :: (self: *Foo, current: s64, freq: s64) -> FC { } main :: () -> void { - f : *Foo = xx malloc(size_of(Foo)); + f : *Foo = xx libc_malloc(size_of(Foo)); f.pixel_w = 2880; f.dpi = 0.0; f.last_perf = 1000; diff --git a/examples/0806-memory-static-method-inline-xx-protocol-arg.sx b/examples/0806-memory-static-method-inline-xx-protocol-arg.sx index 8d03c0a..17a576e 100644 --- a/examples/0806-memory-static-method-inline-xx-protocol-arg.sx +++ b/examples/0806-memory-static-method-inline-xx-protocol-arg.sx @@ -16,7 +16,7 @@ Box :: struct { first_ptr: *void; init :: (parent_alloc: Allocator, size: s64) -> *Box { - self : *Box = xx malloc(size_of(Box)); + self : *Box = xx libc_malloc(size_of(Box)); self.parent = parent_alloc; self.first_ptr = self.parent.alloc_bytes(size); self @@ -24,7 +24,7 @@ Box :: struct { } make_box :: (parent_alloc: Allocator, size: s64) -> *Box { - self : *Box = xx malloc(size_of(Box)); + self : *Box = xx libc_malloc(size_of(Box)); self.parent = parent_alloc; self.first_ptr = self.parent.alloc_bytes(size); self diff --git a/examples/0808-memory-xx-value-routes-through-context-allocator.sx b/examples/0808-memory-xx-value-routes-through-context-allocator.sx index 289702f..802ab8e 100644 --- a/examples/0808-memory-xx-value-routes-through-context-allocator.sx +++ b/examples/0808-memory-xx-value-routes-through-context-allocator.sx @@ -15,7 +15,7 @@ Tracer :: struct { count: s64; init :: () -> *Tracer { - t : *Tracer = xx malloc(size_of(Tracer)); + t : *Tracer = xx libc_malloc(size_of(Tracer)); t.count = 0; t } @@ -24,10 +24,10 @@ Tracer :: struct { impl Allocator for Tracer { alloc_bytes :: (self: *Tracer, size: s64) -> *void { self.count += 1; - return malloc(size); + return libc_malloc(size); } dealloc_bytes :: (self: *Tracer, ptr: *void) { - free(ptr); + libc_free(ptr); } } diff --git a/examples/0838-memory-helpers.sx b/examples/0838-memory-helpers.sx new file mode 100644 index 0000000..89015ec --- /dev/null +++ b/examples/0838-memory-helpers.sx @@ -0,0 +1,61 @@ +// Typed allocation helpers over the Allocator protocol (std/mem.sx): +// create/destroy (one T), alloc/free (slices), clone, resize, and the +// bytes-level mem_realloc. Free functions — direct calls and the +// fluent pipe spelling (`context.allocator |> create(Session)`) hit +// the same generic machinery. Contents are UNINITIALISED by design +// (Zig-aligned): assign before reading. TrackingAllocator balances to +// zero across every pair. + +#import "modules/std.sx"; +#import "modules/std/mem.sx"; + +Session :: struct { id: s64; score: s64; } + +main :: () { + gpa := GPA.init(); + tracker := TrackingAllocator.init(xx gpa); + a : Allocator = xx tracker; + + // create / destroy — direct spelling + s := create(a, Session); + s.id = 7; s.score = 42; + print("create: {} {}\n", s.id, s.score); + destroy(a, s); + + // create — fluent pipe spelling + p := a |> create(Session); + p.id = 1; + print("pipe-create: {}\n", p.id); + a |> destroy(p); + + // alloc / free — typed slice + xs := a |> alloc(s64, 4); + xs[0] = 10; xs[1] = 20; xs[2] = 30; xs[3] = 40; + print("alloc: {} {} len={}\n", xs[0], xs[3], xs.len); + + // clone — independent copy + ys := xs |> clone(a); + xs[0] = 99; + print("clone: {} (orig {})\n", ys[0], xs[0]); + a |> free(ys); + + // resize — grow (copies, old backing freed) + zs := xs |> resize(a, 6); + zs[5] = 60; + print("resize: {} {} len={}\n", zs[1], zs[5], zs.len); + // resize — shrink + ws := zs |> resize(a, 2); + print("shrink: {} {} len={}\n", ws[0], ws[1], ws.len); + a |> free(ws); + + // mem_realloc — bytes level + raw := a.alloc_bytes(8); + q : *s64 = xx raw; + q.* = 1234; + raw2 := mem_realloc(a, raw, 8, 16, 8); + q2 : *s64 = xx raw2; + print("realloc: {}\n", q2.*); + a.dealloc_bytes(raw2); + + tracker.report(); +} diff --git a/examples/1610-platform-uikit-platform.sx b/examples/1610-platform-uikit-platform.sx index 88d495b..3b418a0 100644 --- a/examples/1610-platform-uikit-platform.sx +++ b/examples/1610-platform-uikit-platform.sx @@ -90,7 +90,7 @@ tap_frame :: () { } main :: () -> void { - plat : *UIKitPlatform = xx malloc(size_of(UIKitPlatform)); + plat : *UIKitPlatform = xx libc_malloc(size_of(UIKitPlatform)); plat.init("SxUIKitPlatform", 0, 0); plat.run_frame_loop(closure(tap_frame)); } diff --git a/examples/expected/0031-basic-local-fn-return.ir b/examples/expected/0031-basic-local-fn-return.ir index 694f158..7a95b7d 100644 --- a/examples/expected/0031-basic-local-fn-return.ir +++ b/examples/expected/0031-basic-local-fn-return.ir @@ -1,680 +1,680 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.466 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.467 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.469 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.470 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.471 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.472 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.474 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.475 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [176 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.471 = private constant [9 x i8] c"Overflow\00" -@tag.str.472 = private constant [3 x i8] c"Io\00" -@tag.str.473 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.474 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.475 = private constant [10 x i8] c"BadEscape\00" -@tag.str.476 = private constant [10 x i8] c"BadNumber\00" -@tag.str.477 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.478 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.479 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.480 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.481 = private constant [13 x i8] c"MissingValue\00" -@tag.str.482 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.483 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.471, i64 8 }, { ptr, i64 } { ptr @tag.str.472, i64 2 }, { ptr, i64 } { ptr @tag.str.473, i64 15 }, { ptr, i64 } { ptr @tag.str.474, i64 13 }, { ptr, i64 } { ptr @tag.str.475, i64 9 }, { ptr, i64 } { ptr @tag.str.476, i64 9 }, { ptr, i64 } { ptr @tag.str.477, i64 15 }, { ptr, i64 } { ptr @tag.str.478, i64 14 }, { ptr, i64 } { ptr @tag.str.479, i64 14 }, { ptr, i64 } { ptr @tag.str.480, i64 11 }, { ptr, i64 } { ptr @tag.str.481, i64 12 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 12 }] +@tag.str.476 = private constant [9 x i8] c"Overflow\00" +@tag.str.477 = private constant [3 x i8] c"Io\00" +@tag.str.478 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.479 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.480 = private constant [10 x i8] c"BadEscape\00" +@tag.str.481 = private constant [10 x i8] c"BadNumber\00" +@tag.str.482 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.483 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.484 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.485 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.486 = private constant [13 x i8] c"MissingValue\00" +@tag.str.487 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.488 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.476, i64 8 }, { ptr, i64 } { ptr @tag.str.477, i64 2 }, { ptr, i64 } { ptr @tag.str.478, i64 15 }, { ptr, i64 } { ptr @tag.str.479, i64 13 }, { ptr, i64 } { ptr @tag.str.480, i64 9 }, { ptr, i64 } { ptr @tag.str.481, i64 9 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 14 }, { ptr, i64 } { ptr @tag.str.484, i64 14 }, { ptr, i64 } { ptr @tag.str.485, i64 11 }, { ptr, i64 } { ptr @tag.str.486, i64 12 }, { ptr, i64 } { ptr @tag.str.487, i64 15 }, { ptr, i64 } { ptr @tag.str.488, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.484 = private constant [5 x i8] c"bool\00" -@tn.str.485 = private constant [3 x i8] c"s8\00" -@tn.str.486 = private constant [4 x i8] c"s16\00" -@tn.str.487 = private constant [4 x i8] c"s32\00" -@tn.str.488 = private constant [4 x i8] c"s64\00" -@tn.str.489 = private constant [3 x i8] c"u8\00" -@tn.str.490 = private constant [4 x i8] c"u16\00" -@tn.str.491 = private constant [4 x i8] c"u32\00" -@tn.str.492 = private constant [4 x i8] c"u64\00" -@tn.str.493 = private constant [4 x i8] c"f32\00" -@tn.str.494 = private constant [4 x i8] c"f64\00" -@tn.str.495 = private constant [7 x i8] c"string\00" -@tn.str.496 = private constant [4 x i8] c"Any\00" -@tn.str.497 = private constant [9 x i8] c"noreturn\00" -@tn.str.498 = private constant [6 x i8] c"isize\00" -@tn.str.499 = private constant [6 x i8] c"usize\00" -@tn.str.500 = private constant [5 x i8] c"void\00" -@tn.str.501 = private constant [6 x i8] c"*void\00" -@tn.str.502 = private constant [16 x i8] c"Source_Location\00" -@tn.str.503 = private constant [11 x i8] c"CAllocator\00" -@tn.str.504 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.505 = private constant [4 x i8] c"GPA\00" -@tn.str.506 = private constant [5 x i8] c"*GPA\00" -@tn.str.507 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.508 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.509 = private constant [10 x i8] c"Allocator\00" -@tn.str.510 = private constant [6 x i8] c"Arena\00" -@tn.str.511 = private constant [7 x i8] c"*Arena\00" -@tn.str.512 = private constant [6 x i8] c"[*]u8\00" -@tn.str.513 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.514 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.515 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.516 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.517 = private constant [8 x i8] c"Context\00" -@tn.str.518 = private constant [7 x i8] c"[4]s64\00" -@tn.str.519 = private constant [9 x i8] c"[]string\00" -@tn.str.520 = private constant [9 x i8] c"OpenMode\00" -@tn.str.521 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.522 = private constant [5 x i8] c"File\00" -@tn.str.523 = private constant [6 x i8] c"*File\00" -@tn.str.524 = private constant [6 x i8] c"?File\00" -@tn.str.525 = private constant [8 x i8] c"?string\00" -@tn.str.526 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.527 = private constant [4 x i8] c"*u8\00" -@tn.str.528 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.529 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.530 = private constant [5 x i8] c"*s32\00" -@tn.str.531 = private constant [9 x i8] c"SockAddr\00" -@tn.str.532 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.533 = private constant [5 x i8] c"*u32\00" -@tn.str.534 = private constant [10 x i8] c"JsonError\00" -@tn.str.535 = private constant [6 x i8] c"Array\00" -@tn.str.536 = private constant [7 x i8] c"Object\00" -@tn.str.537 = private constant [6 x i8] c"Value\00" -@tn.str.538 = private constant [7 x i8] c"Member\00" -@tn.str.539 = private constant [9 x i8] c"[*]Value\00" -@tn.str.540 = private constant [7 x i8] c"*Array\00" -@tn.str.541 = private constant [10 x i8] c"[*]Member\00" -@tn.str.542 = private constant [8 x i8] c"*Object\00" -@tn.str.543 = private constant [5 x i8] c"[]u8\00" -@tn.str.544 = private constant [5 x i8] c"Sink\00" -@tn.str.545 = private constant [6 x i8] c"*Sink\00" -@tn.str.546 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.547 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.548 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.549 = private constant [7 x i8] c"Parser\00" -@tn.str.550 = private constant [8 x i8] c"*Parser\00" -@tn.str.551 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.552 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.553 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.554 = private constant [13 x i8] c"Architecture\00" -@tn.str.555 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.556 = private constant [11 x i8] c"() -> bool\00" -@tn.str.557 = private constant [5 x i8] c"*s64\00" -@tn.str.558 = private constant [9 x i8] c"CliError\00" -@tn.str.559 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.560 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.561 = private constant [8 x i8] c"Command\00" -@tn.str.562 = private constant [10 x i8] c"FlagValue\00" -@tn.str.563 = private constant [5 x i8] c"Diag\00" -@tn.str.564 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.565 = private constant [7 x i8] c"Parsed\00" -@tn.str.566 = private constant [8 x i8] c"*Parsed\00" -@tn.str.567 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.568 = private constant [10 x i8] c"[]Command\00" -@tn.str.569 = private constant [6 x i8] c"*Diag\00" -@tn.str.570 = private constant [7 x i8] c"[8]s64\00" -@tn.str.571 = private constant [7 x i8] c"[64]u8\00" -@tn.str.572 = private constant [7 x i8] c"Sha256\00" -@tn.str.573 = private constant [8 x i8] c"*Sha256\00" -@tn.str.574 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.575 = private constant [8 x i8] c"[64]s64\00" -@tn.str.576 = private constant [8 x i8] c"[16]f32\00" -@tn.str.577 = private constant [5 x i8] c"Mat4\00" -@tn.str.578 = private constant [5 x i8] c"Vec2\00" -@tn.str.579 = private constant [6 x i8] c"Point\00" -@tn.str.580 = private constant [11 x i8] c"Shape.rect\00" -@tn.str.581 = private constant [6 x i8] c"Shape\00" -@tn.str.582 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.583 = private constant [7 x i8] c"**void\00" -@tn.str.584 = private constant [8 x i8] c"*string\00" -@tn.str.585 = private constant [6 x i8] c"[]Any\00" -@tn.str.586 = private constant [5 x i8] c"*Any\00" -@tn.str.587 = private constant [7 x i8] c"*[]Any\00" -@tn.str.588 = private constant [6 x i8] c"*bool\00" -@tn.str.589 = private constant [7 x i8] c"*Point\00" -@tn.str.590 = private constant [7 x i8] c"[2]Any\00" -@tn.str.591 = private constant [8 x i8] c"*[2]Any\00" -@tn.str.592 = private constant [7 x i8] c"*Shape\00" -@tn.str.593 = private constant [7 x i8] c"[1]Any\00" -@tn.str.594 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.595 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.596 = private constant [5 x i8] c"*f64\00" -@tn.str.597 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.598 = private constant [11 x i8] c"*Allocator\00" -@tn.str.599 = private constant [9 x i8] c"*Context\00" -@tn.str.600 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.601 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.602 = private constant [8 x i8] c"*Member\00" -@tn.str.603 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.604 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.605 = private constant [9 x i8] c"*Command\00" -@tn.str.606 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.607 = private constant [6 x i8] c"*Mat4\00" -@tn.str.608 = private constant [6 x i8] c"*Vec2\00" -@tn.str.609 = private constant [12 x i8] c"*Shape.rect\00" -@tn.str.610 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.611 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.612 = private constant [7 x i8] c"*Value\00" -@tn.str.613 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.614 = private constant [14 x i8] c"*Architecture\00" -@tn.str.615 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.616 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.617 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.618 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.619 = private constant [9 x i8] c"*[16]f32\00" -@tn.str.620 = private constant [10 x i8] c"*[]string\00" -@tn.str.621 = private constant [6 x i8] c"*[]u8\00" -@tn.str.622 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.623 = private constant [11 x i8] c"*[]Command\00" -@tn.str.624 = private constant [6 x i8] c"**GPA\00" -@tn.str.625 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.626 = private constant [8 x i8] c"**Arena\00" -@tn.str.627 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.628 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.629 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.630 = private constant [7 x i8] c"**File\00" -@tn.str.631 = private constant [5 x i8] c"**u8\00" -@tn.str.632 = private constant [6 x i8] c"**s32\00" -@tn.str.633 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.634 = private constant [6 x i8] c"**u32\00" -@tn.str.635 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.636 = private constant [8 x i8] c"**Array\00" -@tn.str.637 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.638 = private constant [9 x i8] c"**Object\00" -@tn.str.639 = private constant [7 x i8] c"**Sink\00" -@tn.str.640 = private constant [9 x i8] c"**Parser\00" -@tn.str.641 = private constant [6 x i8] c"**s64\00" -@tn.str.642 = private constant [9 x i8] c"**Parsed\00" -@tn.str.643 = private constant [7 x i8] c"**Diag\00" -@tn.str.644 = private constant [9 x i8] c"**Sha256\00" -@tn.str.645 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.646 = private constant [8 x i8] c"***void\00" -@tn.str.647 = private constant [9 x i8] c"**string\00" -@tn.str.648 = private constant [6 x i8] c"**Any\00" -@tn.str.649 = private constant [8 x i8] c"**[]Any\00" -@tn.str.650 = private constant [7 x i8] c"**bool\00" -@tn.str.651 = private constant [8 x i8] c"**Point\00" -@tn.str.652 = private constant [9 x i8] c"**[2]Any\00" -@tn.str.653 = private constant [8 x i8] c"**Shape\00" -@tn.str.654 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.655 = private constant [7 x i8] c"*?File\00" -@tn.str.656 = private constant [9 x i8] c"*?string\00" -@tn.str.657 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.658 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [176 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.484, i64 4 }, { ptr, i64 } { ptr @tn.str.485, i64 2 }, { ptr, i64 } { ptr @tn.str.486, i64 3 }, { ptr, i64 } { ptr @tn.str.487, i64 3 }, { ptr, i64 } { ptr @tn.str.488, i64 3 }, { ptr, i64 } { ptr @tn.str.489, i64 2 }, { ptr, i64 } { ptr @tn.str.490, i64 3 }, { ptr, i64 } { ptr @tn.str.491, i64 3 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 3 }, { ptr, i64 } { ptr @tn.str.495, i64 6 }, { ptr, i64 } { ptr @tn.str.496, i64 3 }, { ptr, i64 } { ptr @tn.str.497, i64 8 }, { ptr, i64 } { ptr @tn.str.498, i64 5 }, { ptr, i64 } { ptr @tn.str.499, i64 5 }, { ptr, i64 } { ptr @tn.str.500, i64 4 }, { ptr, i64 } { ptr @tn.str.501, i64 5 }, { ptr, i64 } { ptr @tn.str.502, i64 15 }, { ptr, i64 } { ptr @tn.str.503, i64 10 }, { ptr, i64 } { ptr @tn.str.504, i64 11 }, { ptr, i64 } { ptr @tn.str.505, i64 3 }, { ptr, i64 } { ptr @tn.str.506, i64 4 }, { ptr, i64 } { ptr @tn.str.507, i64 10 }, { ptr, i64 } { ptr @tn.str.508, i64 11 }, { ptr, i64 } { ptr @tn.str.509, i64 9 }, { ptr, i64 } { ptr @tn.str.510, i64 5 }, { ptr, i64 } { ptr @tn.str.511, i64 6 }, { ptr, i64 } { ptr @tn.str.512, i64 5 }, { ptr, i64 } { ptr @tn.str.513, i64 8 }, { ptr, i64 } { ptr @tn.str.514, i64 9 }, { ptr, i64 } { ptr @tn.str.515, i64 17 }, { ptr, i64 } { ptr @tn.str.516, i64 18 }, { ptr, i64 } { ptr @tn.str.517, i64 7 }, { ptr, i64 } { ptr @tn.str.518, i64 6 }, { ptr, i64 } { ptr @tn.str.519, i64 8 }, { ptr, i64 } { ptr @tn.str.520, i64 8 }, { ptr, i64 } { ptr @tn.str.521, i64 8 }, { ptr, i64 } { ptr @tn.str.522, i64 4 }, { ptr, i64 } { ptr @tn.str.523, i64 5 }, { ptr, i64 } { ptr @tn.str.524, i64 5 }, { ptr, i64 } { ptr @tn.str.525, i64 7 }, { ptr, i64 } { ptr @tn.str.526, i64 10 }, { ptr, i64 } { ptr @tn.str.527, i64 3 }, { ptr, i64 } { ptr @tn.str.528, i64 13 }, { ptr, i64 } { ptr @tn.str.529, i64 14 }, { ptr, i64 } { ptr @tn.str.530, i64 4 }, { ptr, i64 } { ptr @tn.str.531, i64 8 }, { ptr, i64 } { ptr @tn.str.532, i64 9 }, { ptr, i64 } { ptr @tn.str.533, i64 4 }, { ptr, i64 } { ptr @tn.str.534, i64 9 }, { ptr, i64 } { ptr @tn.str.535, i64 5 }, { ptr, i64 } { ptr @tn.str.536, i64 6 }, { ptr, i64 } { ptr @tn.str.537, i64 5 }, { ptr, i64 } { ptr @tn.str.538, i64 6 }, { ptr, i64 } { ptr @tn.str.539, i64 8 }, { ptr, i64 } { ptr @tn.str.540, i64 6 }, { ptr, i64 } { ptr @tn.str.541, i64 9 }, { ptr, i64 } { ptr @tn.str.542, i64 7 }, { ptr, i64 } { ptr @tn.str.543, i64 4 }, { ptr, i64 } { ptr @tn.str.544, i64 4 }, { ptr, i64 } { ptr @tn.str.545, i64 5 }, { ptr, i64 } { ptr @tn.str.546, i64 16 }, { ptr, i64 } { ptr @tn.str.547, i64 14 }, { ptr, i64 } { ptr @tn.str.548, i64 21 }, { ptr, i64 } { ptr @tn.str.549, i64 6 }, { ptr, i64 } { ptr @tn.str.550, i64 7 }, { ptr, i64 } { ptr @tn.str.551, i64 24 }, { ptr, i64 } { ptr @tn.str.552, i64 23 }, { ptr, i64 } { ptr @tn.str.553, i64 15 }, { ptr, i64 } { ptr @tn.str.554, i64 12 }, { ptr, i64 } { ptr @tn.str.555, i64 12 }, { ptr, i64 } { ptr @tn.str.556, i64 10 }, { ptr, i64 } { ptr @tn.str.557, i64 4 }, { ptr, i64 } { ptr @tn.str.558, i64 8 }, { ptr, i64 } { ptr @tn.str.559, i64 8 }, { ptr, i64 } { ptr @tn.str.560, i64 10 }, { ptr, i64 } { ptr @tn.str.561, i64 7 }, { ptr, i64 } { ptr @tn.str.562, i64 9 }, { ptr, i64 } { ptr @tn.str.563, i64 4 }, { ptr, i64 } { ptr @tn.str.564, i64 13 }, { ptr, i64 } { ptr @tn.str.565, i64 6 }, { ptr, i64 } { ptr @tn.str.566, i64 7 }, { ptr, i64 } { ptr @tn.str.567, i64 18 }, { ptr, i64 } { ptr @tn.str.568, i64 9 }, { ptr, i64 } { ptr @tn.str.569, i64 5 }, { ptr, i64 } { ptr @tn.str.570, i64 6 }, { ptr, i64 } { ptr @tn.str.571, i64 6 }, { ptr, i64 } { ptr @tn.str.572, i64 6 }, { ptr, i64 } { ptr @tn.str.573, i64 7 }, { ptr, i64 } { ptr @tn.str.574, i64 7 }, { ptr, i64 } { ptr @tn.str.575, i64 7 }, { ptr, i64 } { ptr @tn.str.576, i64 7 }, { ptr, i64 } { ptr @tn.str.577, i64 4 }, { ptr, i64 } { ptr @tn.str.578, i64 4 }, { ptr, i64 } { ptr @tn.str.579, i64 5 }, { ptr, i64 } { ptr @tn.str.580, i64 10 }, { ptr, i64 } { ptr @tn.str.581, i64 5 }, { ptr, i64 } { ptr @tn.str.582, i64 12 }, { ptr, i64 } { ptr @tn.str.583, i64 6 }, { ptr, i64 } { ptr @tn.str.584, i64 7 }, { ptr, i64 } { ptr @tn.str.585, i64 5 }, { ptr, i64 } { ptr @tn.str.586, i64 4 }, { ptr, i64 } { ptr @tn.str.587, i64 6 }, { ptr, i64 } { ptr @tn.str.588, i64 5 }, { ptr, i64 } { ptr @tn.str.589, i64 6 }, { ptr, i64 } { ptr @tn.str.590, i64 6 }, { ptr, i64 } { ptr @tn.str.591, i64 7 }, { ptr, i64 } { ptr @tn.str.592, i64 6 }, { ptr, i64 } { ptr @tn.str.593, i64 6 }, { ptr, i64 } { ptr @tn.str.594, i64 7 }, { ptr, i64 } { ptr @tn.str.595, i64 7 }, { ptr, i64 } { ptr @tn.str.596, i64 4 }, { ptr, i64 } { ptr @tn.str.597, i64 16 }, { ptr, i64 } { ptr @tn.str.598, i64 10 }, { ptr, i64 } { ptr @tn.str.599, i64 8 }, { ptr, i64 } { ptr @tn.str.600, i64 11 }, { ptr, i64 } { ptr @tn.str.601, i64 14 }, { ptr, i64 } { ptr @tn.str.602, i64 7 }, { ptr, i64 } { ptr @tn.str.603, i64 13 }, { ptr, i64 } { ptr @tn.str.604, i64 9 }, { ptr, i64 } { ptr @tn.str.605, i64 8 }, { ptr, i64 } { ptr @tn.str.606, i64 10 }, { ptr, i64 } { ptr @tn.str.607, i64 5 }, { ptr, i64 } { ptr @tn.str.608, i64 5 }, { ptr, i64 } { ptr @tn.str.609, i64 11 }, { ptr, i64 } { ptr @tn.str.610, i64 9 }, { ptr, i64 } { ptr @tn.str.611, i64 9 }, { ptr, i64 } { ptr @tn.str.612, i64 6 }, { ptr, i64 } { ptr @tn.str.613, i64 16 }, { ptr, i64 } { ptr @tn.str.614, i64 13 }, { ptr, i64 } { ptr @tn.str.615, i64 14 }, { ptr, i64 } { ptr @tn.str.616, i64 7 }, { ptr, i64 } { ptr @tn.str.617, i64 7 }, { ptr, i64 } { ptr @tn.str.618, i64 8 }, { ptr, i64 } { ptr @tn.str.619, i64 8 }, { ptr, i64 } { ptr @tn.str.620, i64 9 }, { ptr, i64 } { ptr @tn.str.621, i64 5 }, { ptr, i64 } { ptr @tn.str.622, i64 11 }, { ptr, i64 } { ptr @tn.str.623, i64 10 }, { ptr, i64 } { ptr @tn.str.624, i64 5 }, { ptr, i64 } { ptr @tn.str.625, i64 12 }, { ptr, i64 } { ptr @tn.str.626, i64 7 }, { ptr, i64 } { ptr @tn.str.627, i64 6 }, { ptr, i64 } { ptr @tn.str.628, i64 10 }, { ptr, i64 } { ptr @tn.str.629, i64 19 }, { ptr, i64 } { ptr @tn.str.630, i64 6 }, { ptr, i64 } { ptr @tn.str.631, i64 4 }, { ptr, i64 } { ptr @tn.str.632, i64 5 }, { ptr, i64 } { ptr @tn.str.633, i64 10 }, { ptr, i64 } { ptr @tn.str.634, i64 5 }, { ptr, i64 } { ptr @tn.str.635, i64 9 }, { ptr, i64 } { ptr @tn.str.636, i64 7 }, { ptr, i64 } { ptr @tn.str.637, i64 10 }, { ptr, i64 } { ptr @tn.str.638, i64 8 }, { ptr, i64 } { ptr @tn.str.639, i64 6 }, { ptr, i64 } { ptr @tn.str.640, i64 8 }, { ptr, i64 } { ptr @tn.str.641, i64 5 }, { ptr, i64 } { ptr @tn.str.642, i64 8 }, { ptr, i64 } { ptr @tn.str.643, i64 6 }, { ptr, i64 } { ptr @tn.str.644, i64 8 }, { ptr, i64 } { ptr @tn.str.645, i64 13 }, { ptr, i64 } { ptr @tn.str.646, i64 7 }, { ptr, i64 } { ptr @tn.str.647, i64 8 }, { ptr, i64 } { ptr @tn.str.648, i64 5 }, { ptr, i64 } { ptr @tn.str.649, i64 7 }, { ptr, i64 } { ptr @tn.str.650, i64 6 }, { ptr, i64 } { ptr @tn.str.651, i64 7 }, { ptr, i64 } { ptr @tn.str.652, i64 8 }, { ptr, i64 } { ptr @tn.str.653, i64 7 }, { ptr, i64 } { ptr @tn.str.654, i64 8 }, { ptr, i64 } { ptr @tn.str.655, i64 6 }, { ptr, i64 } { ptr @tn.str.656, i64 8 }, { ptr, i64 } { ptr @tn.str.657, i64 15 }, { ptr, i64 } { ptr @tn.str.658, i64 8 }] -@str.659 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.660 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.661 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.662 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.663 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.489 = private constant [5 x i8] c"bool\00" +@tn.str.490 = private constant [3 x i8] c"s8\00" +@tn.str.491 = private constant [4 x i8] c"s16\00" +@tn.str.492 = private constant [4 x i8] c"s32\00" +@tn.str.493 = private constant [4 x i8] c"s64\00" +@tn.str.494 = private constant [3 x i8] c"u8\00" +@tn.str.495 = private constant [4 x i8] c"u16\00" +@tn.str.496 = private constant [4 x i8] c"u32\00" +@tn.str.497 = private constant [4 x i8] c"u64\00" +@tn.str.498 = private constant [4 x i8] c"f32\00" +@tn.str.499 = private constant [4 x i8] c"f64\00" +@tn.str.500 = private constant [7 x i8] c"string\00" +@tn.str.501 = private constant [4 x i8] c"Any\00" +@tn.str.502 = private constant [9 x i8] c"noreturn\00" +@tn.str.503 = private constant [6 x i8] c"isize\00" +@tn.str.504 = private constant [6 x i8] c"usize\00" +@tn.str.505 = private constant [5 x i8] c"void\00" +@tn.str.506 = private constant [6 x i8] c"*void\00" +@tn.str.507 = private constant [16 x i8] c"Source_Location\00" +@tn.str.508 = private constant [10 x i8] c"Allocator\00" +@tn.str.509 = private constant [11 x i8] c"CAllocator\00" +@tn.str.510 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.511 = private constant [4 x i8] c"GPA\00" +@tn.str.512 = private constant [5 x i8] c"*GPA\00" +@tn.str.513 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.514 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.515 = private constant [6 x i8] c"Arena\00" +@tn.str.516 = private constant [7 x i8] c"*Arena\00" +@tn.str.517 = private constant [6 x i8] c"[*]u8\00" +@tn.str.518 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.519 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.520 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.521 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.522 = private constant [8 x i8] c"Context\00" +@tn.str.523 = private constant [7 x i8] c"[4]s64\00" +@tn.str.524 = private constant [9 x i8] c"[]string\00" +@tn.str.525 = private constant [9 x i8] c"OpenMode\00" +@tn.str.526 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.527 = private constant [5 x i8] c"File\00" +@tn.str.528 = private constant [6 x i8] c"*File\00" +@tn.str.529 = private constant [6 x i8] c"?File\00" +@tn.str.530 = private constant [8 x i8] c"?string\00" +@tn.str.531 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.532 = private constant [4 x i8] c"*u8\00" +@tn.str.533 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.534 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.535 = private constant [5 x i8] c"*s32\00" +@tn.str.536 = private constant [9 x i8] c"SockAddr\00" +@tn.str.537 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.538 = private constant [5 x i8] c"*u32\00" +@tn.str.539 = private constant [10 x i8] c"JsonError\00" +@tn.str.540 = private constant [6 x i8] c"Array\00" +@tn.str.541 = private constant [7 x i8] c"Object\00" +@tn.str.542 = private constant [6 x i8] c"Value\00" +@tn.str.543 = private constant [7 x i8] c"Member\00" +@tn.str.544 = private constant [9 x i8] c"[*]Value\00" +@tn.str.545 = private constant [7 x i8] c"*Array\00" +@tn.str.546 = private constant [10 x i8] c"[*]Member\00" +@tn.str.547 = private constant [8 x i8] c"*Object\00" +@tn.str.548 = private constant [5 x i8] c"[]u8\00" +@tn.str.549 = private constant [5 x i8] c"Sink\00" +@tn.str.550 = private constant [6 x i8] c"*Sink\00" +@tn.str.551 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.552 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.553 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.554 = private constant [7 x i8] c"Parser\00" +@tn.str.555 = private constant [8 x i8] c"*Parser\00" +@tn.str.556 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.557 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.558 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.559 = private constant [13 x i8] c"Architecture\00" +@tn.str.560 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.561 = private constant [11 x i8] c"() -> bool\00" +@tn.str.562 = private constant [5 x i8] c"*s64\00" +@tn.str.563 = private constant [9 x i8] c"CliError\00" +@tn.str.564 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.565 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.566 = private constant [8 x i8] c"Command\00" +@tn.str.567 = private constant [10 x i8] c"FlagValue\00" +@tn.str.568 = private constant [5 x i8] c"Diag\00" +@tn.str.569 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.570 = private constant [7 x i8] c"Parsed\00" +@tn.str.571 = private constant [8 x i8] c"*Parsed\00" +@tn.str.572 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.573 = private constant [10 x i8] c"[]Command\00" +@tn.str.574 = private constant [6 x i8] c"*Diag\00" +@tn.str.575 = private constant [7 x i8] c"[8]s64\00" +@tn.str.576 = private constant [7 x i8] c"[64]u8\00" +@tn.str.577 = private constant [7 x i8] c"Sha256\00" +@tn.str.578 = private constant [8 x i8] c"*Sha256\00" +@tn.str.579 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.580 = private constant [8 x i8] c"[64]s64\00" +@tn.str.581 = private constant [8 x i8] c"[16]f32\00" +@tn.str.582 = private constant [5 x i8] c"Mat4\00" +@tn.str.583 = private constant [5 x i8] c"Vec2\00" +@tn.str.584 = private constant [6 x i8] c"Point\00" +@tn.str.585 = private constant [11 x i8] c"Shape.rect\00" +@tn.str.586 = private constant [6 x i8] c"Shape\00" +@tn.str.587 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.588 = private constant [7 x i8] c"**void\00" +@tn.str.589 = private constant [8 x i8] c"*string\00" +@tn.str.590 = private constant [6 x i8] c"[]Any\00" +@tn.str.591 = private constant [5 x i8] c"*Any\00" +@tn.str.592 = private constant [7 x i8] c"*[]Any\00" +@tn.str.593 = private constant [6 x i8] c"*bool\00" +@tn.str.594 = private constant [7 x i8] c"*Point\00" +@tn.str.595 = private constant [7 x i8] c"[2]Any\00" +@tn.str.596 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.597 = private constant [7 x i8] c"*Shape\00" +@tn.str.598 = private constant [7 x i8] c"[1]Any\00" +@tn.str.599 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.600 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.601 = private constant [5 x i8] c"*f64\00" +@tn.str.602 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.603 = private constant [11 x i8] c"*Allocator\00" +@tn.str.604 = private constant [9 x i8] c"*Context\00" +@tn.str.605 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.606 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.607 = private constant [8 x i8] c"*Member\00" +@tn.str.608 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.609 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.610 = private constant [9 x i8] c"*Command\00" +@tn.str.611 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.612 = private constant [6 x i8] c"*Mat4\00" +@tn.str.613 = private constant [6 x i8] c"*Vec2\00" +@tn.str.614 = private constant [12 x i8] c"*Shape.rect\00" +@tn.str.615 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.616 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.617 = private constant [7 x i8] c"*Value\00" +@tn.str.618 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.619 = private constant [14 x i8] c"*Architecture\00" +@tn.str.620 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.621 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.622 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.623 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.624 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.625 = private constant [10 x i8] c"*[]string\00" +@tn.str.626 = private constant [6 x i8] c"*[]u8\00" +@tn.str.627 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.628 = private constant [11 x i8] c"*[]Command\00" +@tn.str.629 = private constant [6 x i8] c"**GPA\00" +@tn.str.630 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.631 = private constant [8 x i8] c"**Arena\00" +@tn.str.632 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.633 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.634 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.635 = private constant [7 x i8] c"**File\00" +@tn.str.636 = private constant [5 x i8] c"**u8\00" +@tn.str.637 = private constant [6 x i8] c"**s32\00" +@tn.str.638 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.639 = private constant [6 x i8] c"**u32\00" +@tn.str.640 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.641 = private constant [8 x i8] c"**Array\00" +@tn.str.642 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.643 = private constant [9 x i8] c"**Object\00" +@tn.str.644 = private constant [7 x i8] c"**Sink\00" +@tn.str.645 = private constant [9 x i8] c"**Parser\00" +@tn.str.646 = private constant [6 x i8] c"**s64\00" +@tn.str.647 = private constant [9 x i8] c"**Parsed\00" +@tn.str.648 = private constant [7 x i8] c"**Diag\00" +@tn.str.649 = private constant [9 x i8] c"**Sha256\00" +@tn.str.650 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.651 = private constant [8 x i8] c"***void\00" +@tn.str.652 = private constant [9 x i8] c"**string\00" +@tn.str.653 = private constant [6 x i8] c"**Any\00" +@tn.str.654 = private constant [8 x i8] c"**[]Any\00" +@tn.str.655 = private constant [7 x i8] c"**bool\00" +@tn.str.656 = private constant [8 x i8] c"**Point\00" +@tn.str.657 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.658 = private constant [8 x i8] c"**Shape\00" +@tn.str.659 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.660 = private constant [7 x i8] c"*?File\00" +@tn.str.661 = private constant [9 x i8] c"*?string\00" +@tn.str.662 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.663 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [176 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.489, i64 4 }, { ptr, i64 } { ptr @tn.str.490, i64 2 }, { ptr, i64 } { ptr @tn.str.491, i64 3 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 2 }, { ptr, i64 } { ptr @tn.str.495, i64 3 }, { ptr, i64 } { ptr @tn.str.496, i64 3 }, { ptr, i64 } { ptr @tn.str.497, i64 3 }, { ptr, i64 } { ptr @tn.str.498, i64 3 }, { ptr, i64 } { ptr @tn.str.499, i64 3 }, { ptr, i64 } { ptr @tn.str.500, i64 6 }, { ptr, i64 } { ptr @tn.str.501, i64 3 }, { ptr, i64 } { ptr @tn.str.502, i64 8 }, { ptr, i64 } { ptr @tn.str.503, i64 5 }, { ptr, i64 } { ptr @tn.str.504, i64 5 }, { ptr, i64 } { ptr @tn.str.505, i64 4 }, { ptr, i64 } { ptr @tn.str.506, i64 5 }, { ptr, i64 } { ptr @tn.str.507, i64 15 }, { ptr, i64 } { ptr @tn.str.508, i64 9 }, { ptr, i64 } { ptr @tn.str.509, i64 10 }, { ptr, i64 } { ptr @tn.str.510, i64 11 }, { ptr, i64 } { ptr @tn.str.511, i64 3 }, { ptr, i64 } { ptr @tn.str.512, i64 4 }, { ptr, i64 } { ptr @tn.str.513, i64 10 }, { ptr, i64 } { ptr @tn.str.514, i64 11 }, { ptr, i64 } { ptr @tn.str.515, i64 5 }, { ptr, i64 } { ptr @tn.str.516, i64 6 }, { ptr, i64 } { ptr @tn.str.517, i64 5 }, { ptr, i64 } { ptr @tn.str.518, i64 8 }, { ptr, i64 } { ptr @tn.str.519, i64 9 }, { ptr, i64 } { ptr @tn.str.520, i64 17 }, { ptr, i64 } { ptr @tn.str.521, i64 18 }, { ptr, i64 } { ptr @tn.str.522, i64 7 }, { ptr, i64 } { ptr @tn.str.523, i64 6 }, { ptr, i64 } { ptr @tn.str.524, i64 8 }, { ptr, i64 } { ptr @tn.str.525, i64 8 }, { ptr, i64 } { ptr @tn.str.526, i64 8 }, { ptr, i64 } { ptr @tn.str.527, i64 4 }, { ptr, i64 } { ptr @tn.str.528, i64 5 }, { ptr, i64 } { ptr @tn.str.529, i64 5 }, { ptr, i64 } { ptr @tn.str.530, i64 7 }, { ptr, i64 } { ptr @tn.str.531, i64 10 }, { ptr, i64 } { ptr @tn.str.532, i64 3 }, { ptr, i64 } { ptr @tn.str.533, i64 13 }, { ptr, i64 } { ptr @tn.str.534, i64 14 }, { ptr, i64 } { ptr @tn.str.535, i64 4 }, { ptr, i64 } { ptr @tn.str.536, i64 8 }, { ptr, i64 } { ptr @tn.str.537, i64 9 }, { ptr, i64 } { ptr @tn.str.538, i64 4 }, { ptr, i64 } { ptr @tn.str.539, i64 9 }, { ptr, i64 } { ptr @tn.str.540, i64 5 }, { ptr, i64 } { ptr @tn.str.541, i64 6 }, { ptr, i64 } { ptr @tn.str.542, i64 5 }, { ptr, i64 } { ptr @tn.str.543, i64 6 }, { ptr, i64 } { ptr @tn.str.544, i64 8 }, { ptr, i64 } { ptr @tn.str.545, i64 6 }, { ptr, i64 } { ptr @tn.str.546, i64 9 }, { ptr, i64 } { ptr @tn.str.547, i64 7 }, { ptr, i64 } { ptr @tn.str.548, i64 4 }, { ptr, i64 } { ptr @tn.str.549, i64 4 }, { ptr, i64 } { ptr @tn.str.550, i64 5 }, { ptr, i64 } { ptr @tn.str.551, i64 16 }, { ptr, i64 } { ptr @tn.str.552, i64 14 }, { ptr, i64 } { ptr @tn.str.553, i64 21 }, { ptr, i64 } { ptr @tn.str.554, i64 6 }, { ptr, i64 } { ptr @tn.str.555, i64 7 }, { ptr, i64 } { ptr @tn.str.556, i64 24 }, { ptr, i64 } { ptr @tn.str.557, i64 23 }, { ptr, i64 } { ptr @tn.str.558, i64 15 }, { ptr, i64 } { ptr @tn.str.559, i64 12 }, { ptr, i64 } { ptr @tn.str.560, i64 12 }, { ptr, i64 } { ptr @tn.str.561, i64 10 }, { ptr, i64 } { ptr @tn.str.562, i64 4 }, { ptr, i64 } { ptr @tn.str.563, i64 8 }, { ptr, i64 } { ptr @tn.str.564, i64 8 }, { ptr, i64 } { ptr @tn.str.565, i64 10 }, { ptr, i64 } { ptr @tn.str.566, i64 7 }, { ptr, i64 } { ptr @tn.str.567, i64 9 }, { ptr, i64 } { ptr @tn.str.568, i64 4 }, { ptr, i64 } { ptr @tn.str.569, i64 13 }, { ptr, i64 } { ptr @tn.str.570, i64 6 }, { ptr, i64 } { ptr @tn.str.571, i64 7 }, { ptr, i64 } { ptr @tn.str.572, i64 18 }, { ptr, i64 } { ptr @tn.str.573, i64 9 }, { ptr, i64 } { ptr @tn.str.574, i64 5 }, { ptr, i64 } { ptr @tn.str.575, i64 6 }, { ptr, i64 } { ptr @tn.str.576, i64 6 }, { ptr, i64 } { ptr @tn.str.577, i64 6 }, { ptr, i64 } { ptr @tn.str.578, i64 7 }, { ptr, i64 } { ptr @tn.str.579, i64 7 }, { ptr, i64 } { ptr @tn.str.580, i64 7 }, { ptr, i64 } { ptr @tn.str.581, i64 7 }, { ptr, i64 } { ptr @tn.str.582, i64 4 }, { ptr, i64 } { ptr @tn.str.583, i64 4 }, { ptr, i64 } { ptr @tn.str.584, i64 5 }, { ptr, i64 } { ptr @tn.str.585, i64 10 }, { ptr, i64 } { ptr @tn.str.586, i64 5 }, { ptr, i64 } { ptr @tn.str.587, i64 12 }, { ptr, i64 } { ptr @tn.str.588, i64 6 }, { ptr, i64 } { ptr @tn.str.589, i64 7 }, { ptr, i64 } { ptr @tn.str.590, i64 5 }, { ptr, i64 } { ptr @tn.str.591, i64 4 }, { ptr, i64 } { ptr @tn.str.592, i64 6 }, { ptr, i64 } { ptr @tn.str.593, i64 5 }, { ptr, i64 } { ptr @tn.str.594, i64 6 }, { ptr, i64 } { ptr @tn.str.595, i64 6 }, { ptr, i64 } { ptr @tn.str.596, i64 7 }, { ptr, i64 } { ptr @tn.str.597, i64 6 }, { ptr, i64 } { ptr @tn.str.598, i64 6 }, { ptr, i64 } { ptr @tn.str.599, i64 7 }, { ptr, i64 } { ptr @tn.str.600, i64 7 }, { ptr, i64 } { ptr @tn.str.601, i64 4 }, { ptr, i64 } { ptr @tn.str.602, i64 16 }, { ptr, i64 } { ptr @tn.str.603, i64 10 }, { ptr, i64 } { ptr @tn.str.604, i64 8 }, { ptr, i64 } { ptr @tn.str.605, i64 11 }, { ptr, i64 } { ptr @tn.str.606, i64 14 }, { ptr, i64 } { ptr @tn.str.607, i64 7 }, { ptr, i64 } { ptr @tn.str.608, i64 13 }, { ptr, i64 } { ptr @tn.str.609, i64 9 }, { ptr, i64 } { ptr @tn.str.610, i64 8 }, { ptr, i64 } { ptr @tn.str.611, i64 10 }, { ptr, i64 } { ptr @tn.str.612, i64 5 }, { ptr, i64 } { ptr @tn.str.613, i64 5 }, { ptr, i64 } { ptr @tn.str.614, i64 11 }, { ptr, i64 } { ptr @tn.str.615, i64 9 }, { ptr, i64 } { ptr @tn.str.616, i64 9 }, { ptr, i64 } { ptr @tn.str.617, i64 6 }, { ptr, i64 } { ptr @tn.str.618, i64 16 }, { ptr, i64 } { ptr @tn.str.619, i64 13 }, { ptr, i64 } { ptr @tn.str.620, i64 14 }, { ptr, i64 } { ptr @tn.str.621, i64 7 }, { ptr, i64 } { ptr @tn.str.622, i64 7 }, { ptr, i64 } { ptr @tn.str.623, i64 8 }, { ptr, i64 } { ptr @tn.str.624, i64 8 }, { ptr, i64 } { ptr @tn.str.625, i64 9 }, { ptr, i64 } { ptr @tn.str.626, i64 5 }, { ptr, i64 } { ptr @tn.str.627, i64 11 }, { ptr, i64 } { ptr @tn.str.628, i64 10 }, { ptr, i64 } { ptr @tn.str.629, i64 5 }, { ptr, i64 } { ptr @tn.str.630, i64 12 }, { ptr, i64 } { ptr @tn.str.631, i64 7 }, { ptr, i64 } { ptr @tn.str.632, i64 6 }, { ptr, i64 } { ptr @tn.str.633, i64 10 }, { ptr, i64 } { ptr @tn.str.634, i64 19 }, { ptr, i64 } { ptr @tn.str.635, i64 6 }, { ptr, i64 } { ptr @tn.str.636, i64 4 }, { ptr, i64 } { ptr @tn.str.637, i64 5 }, { ptr, i64 } { ptr @tn.str.638, i64 10 }, { ptr, i64 } { ptr @tn.str.639, i64 5 }, { ptr, i64 } { ptr @tn.str.640, i64 9 }, { ptr, i64 } { ptr @tn.str.641, i64 7 }, { ptr, i64 } { ptr @tn.str.642, i64 10 }, { ptr, i64 } { ptr @tn.str.643, i64 8 }, { ptr, i64 } { ptr @tn.str.644, i64 6 }, { ptr, i64 } { ptr @tn.str.645, i64 8 }, { ptr, i64 } { ptr @tn.str.646, i64 5 }, { ptr, i64 } { ptr @tn.str.647, i64 8 }, { ptr, i64 } { ptr @tn.str.648, i64 6 }, { ptr, i64 } { ptr @tn.str.649, i64 8 }, { ptr, i64 } { ptr @tn.str.650, i64 13 }, { ptr, i64 } { ptr @tn.str.651, i64 7 }, { ptr, i64 } { ptr @tn.str.652, i64 8 }, { ptr, i64 } { ptr @tn.str.653, i64 5 }, { ptr, i64 } { ptr @tn.str.654, i64 7 }, { ptr, i64 } { ptr @tn.str.655, i64 6 }, { ptr, i64 } { ptr @tn.str.656, i64 7 }, { ptr, i64 } { ptr @tn.str.657, i64 8 }, { ptr, i64 } { ptr @tn.str.658, i64 7 }, { ptr, i64 } { ptr @tn.str.659, i64 8 }, { ptr, i64 } { ptr @tn.str.660, i64 6 }, { ptr, i64 } { ptr @tn.str.661, i64 8 }, { ptr, i64 } { ptr @tn.str.662, i64 15 }, { ptr, i64 } { ptr @tn.str.663, i64 8 }] @str.664 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.665 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.666 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.669 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.670 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.665 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.666 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.667 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.668 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.669 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.670 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 @str.671 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 @str.672 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.673 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.674 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.675 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.677 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.678 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.680 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 -@str.681 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.682 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 -@str.683 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 -@str.684 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.685 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 -@str.686 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 -@str.687 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.688 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 -@str.689 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.690 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.691 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.674 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.675 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.676 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.677 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.679 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.680 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.682 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.683 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.685 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 +@str.686 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.687 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 +@str.688 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 +@str.689 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.690 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 +@str.691 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 +@str.692 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.693 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 +@str.694 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.695 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.696 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.693 = private constant [5 x i8] c"line\00" -@fld.str.694 = private constant [4 x i8] c"col\00" -@fld.str.695 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.693, i64 4 }, { ptr, i64 } { ptr @fld.str.694, i64 3 }, { ptr, i64 } { ptr @fld.str.695, i64 4 }] -@str.696 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.697 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.698 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.699 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.700 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.701 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.702 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.704 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.705 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.706 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.707 = private constant [12 x i8] c"alloc_count\00" -@field_names.708 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.707, i64 11 }] -@str.709 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.710 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.711 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.712 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.713 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.714 = private constant [5 x i8] c"next\00" -@fld.str.715 = private constant [4 x i8] c"cap\00" -@field_names.716 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.714, i64 4 }, { ptr, i64 } { ptr @fld.str.715, i64 3 }] -@str.717 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.718 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.719 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.720 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.721 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.722 = private constant [4 x i8] c"ctx\00" -@fld.str.723 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.724 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.725 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.722, i64 3 }, { ptr, i64 } { ptr @fld.str.723, i64 11 }, { ptr, i64 } { ptr @fld.str.724, i64 13 }] -@str.726 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.727 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.728 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.729 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.730 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.731 = private constant [6 x i8] c"first\00" -@fld.str.732 = private constant [10 x i8] c"end_index\00" -@fld.str.733 = private constant [7 x i8] c"parent\00" -@field_names.734 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.731, i64 5 }, { ptr, i64 } { ptr @fld.str.732, i64 9 }, { ptr, i64 } { ptr @fld.str.733, i64 6 }] -@str.735 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.736 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.737 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.738 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.739 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.740 = private constant [4 x i8] c"buf\00" -@fld.str.741 = private constant [4 x i8] c"len\00" -@fld.str.742 = private constant [4 x i8] c"pos\00" -@field_names.743 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.740, i64 3 }, { ptr, i64 } { ptr @fld.str.741, i64 3 }, { ptr, i64 } { ptr @fld.str.742, i64 3 }] -@str.744 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.745 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.746 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.747 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.748 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.749 = private constant [7 x i8] c"parent\00" -@fld.str.750 = private constant [12 x i8] c"alloc_count\00" -@fld.str.751 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.752 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.753 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.749, i64 6 }, { ptr, i64 } { ptr @fld.str.750, i64 11 }, { ptr, i64 } { ptr @fld.str.751, i64 13 }, { ptr, i64 } { ptr @fld.str.752, i64 17 }] -@str.754 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.755 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.756 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.757 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.758 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.759 = private constant [10 x i8] c"allocator\00" -@fld.str.760 = private constant [5 x i8] c"data\00" -@field_names.761 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.759, i64 9 }, { ptr, i64 } { ptr @fld.str.760, i64 4 }] -@str.762 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.763 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.764 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.765 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.766 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.767 = private constant [3 x i8] c"fd\00" -@field_names.768 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.767, i64 2 }] -@str.769 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.770 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.771 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.772 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.773 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.774 = private constant [5 x i8] c"file\00" -@fld.str.775 = private constant [5 x i8] c"line\00" -@fld.str.776 = private constant [4 x i8] c"col\00" -@fld.str.777 = private constant [5 x i8] c"func\00" -@fld.str.778 = private constant [10 x i8] c"line_text\00" -@field_names.779 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.774, i64 4 }, { ptr, i64 } { ptr @fld.str.775, i64 4 }, { ptr, i64 } { ptr @fld.str.776, i64 3 }, { ptr, i64 } { ptr @fld.str.777, i64 4 }, { ptr, i64 } { ptr @fld.str.778, i64 9 }] -@str.780 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.781 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.782 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.783 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.784 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.785 = private constant [10 x i8] c"exit_code\00" -@fld.str.786 = private constant [7 x i8] c"stdout\00" -@field_names.787 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.785, i64 9 }, { ptr, i64 } { ptr @fld.str.786, i64 6 }] -@str.788 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.789 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.790 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.791 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.792 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.793 = private constant [8 x i8] c"sin_len\00" -@fld.str.794 = private constant [11 x i8] c"sin_family\00" -@fld.str.795 = private constant [9 x i8] c"sin_port\00" -@fld.str.796 = private constant [9 x i8] c"sin_addr\00" -@fld.str.797 = private constant [9 x i8] c"sin_zero\00" -@field_names.798 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.793, i64 7 }, { ptr, i64 } { ptr @fld.str.794, i64 10 }, { ptr, i64 } { ptr @fld.str.795, i64 8 }, { ptr, i64 } { ptr @fld.str.796, i64 8 }, { ptr, i64 } { ptr @fld.str.797, i64 8 }] -@str.799 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.800 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.801 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.802 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.803 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.804 = private constant [6 x i8] c"items\00" -@fld.str.805 = private constant [4 x i8] c"len\00" -@fld.str.806 = private constant [4 x i8] c"cap\00" -@field_names.807 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.804, i64 5 }, { ptr, i64 } { ptr @fld.str.805, i64 3 }, { ptr, i64 } { ptr @fld.str.806, i64 3 }] -@str.808 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.809 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.810 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.811 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.812 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.813 = private constant [6 x i8] c"items\00" -@fld.str.814 = private constant [4 x i8] c"len\00" -@fld.str.815 = private constant [4 x i8] c"cap\00" -@field_names.816 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.813, i64 5 }, { ptr, i64 } { ptr @fld.str.814, i64 3 }, { ptr, i64 } { ptr @fld.str.815, i64 3 }] -@str.817 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.818 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.819 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.820 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.821 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.822 = private constant [4 x i8] c"key\00" -@fld.str.823 = private constant [4 x i8] c"val\00" -@field_names.824 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.822, i64 3 }, { ptr, i64 } { ptr @fld.str.823, i64 3 }] -@str.825 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.826 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.827 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.828 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.829 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.830 = private constant [4 x i8] c"dst\00" -@fld.str.831 = private constant [4 x i8] c"pos\00" -@fld.str.832 = private constant [5 x i8] c"file\00" -@field_names.833 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.830, i64 3 }, { ptr, i64 } { ptr @fld.str.831, i64 3 }, { ptr, i64 } { ptr @fld.str.832, i64 4 }] -@str.834 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.835 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.836 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.837 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.838 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.839 = private constant [4 x i8] c"src\00" -@fld.str.840 = private constant [4 x i8] c"pos\00" -@fld.str.841 = private constant [6 x i8] c"alloc\00" -@field_names.842 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.839, i64 3 }, { ptr, i64 } { ptr @fld.str.840, i64 3 }, { ptr, i64 } { ptr @fld.str.841, i64 5 }] -@str.843 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.844 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.845 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.846 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.847 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.848 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.849 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.850 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.851 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.852 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.853 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.854 = private constant [5 x i8] c"name\00" -@fld.str.855 = private constant [12 x i8] c"takes_value\00" -@fld.str.856 = private constant [9 x i8] c"required\00" -@field_names.857 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.854, i64 4 }, { ptr, i64 } { ptr @fld.str.855, i64 11 }, { ptr, i64 } { ptr @fld.str.856, i64 8 }] -@str.858 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.859 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.860 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.861 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.862 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.863 = private constant [6 x i8] c"group\00" -@fld.str.864 = private constant [8 x i8] c"command\00" -@fld.str.865 = private constant [6 x i8] c"flags\00" -@field_names.866 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.863, i64 5 }, { ptr, i64 } { ptr @fld.str.864, i64 7 }, { ptr, i64 } { ptr @fld.str.865, i64 5 }] -@str.867 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.868 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.869 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.870 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.871 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.872 = private constant [4 x i8] c"set\00" -@fld.str.873 = private constant [6 x i8] c"value\00" -@field_names.874 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.872, i64 3 }, { ptr, i64 } { ptr @fld.str.873, i64 5 }] -@str.875 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.876 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.877 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.878 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.879 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.880 = private constant [6 x i8] c"index\00" -@fld.str.881 = private constant [6 x i8] c"token\00" -@field_names.882 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.880, i64 5 }, { ptr, i64 } { ptr @fld.str.881, i64 5 }] -@str.883 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.884 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.885 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.886 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.887 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.888 = private constant [6 x i8] c"group\00" -@fld.str.889 = private constant [8 x i8] c"command\00" -@fld.str.890 = private constant [10 x i8] c"cmd_index\00" -@fld.str.891 = private constant [5 x i8] c"json\00" -@fld.str.892 = private constant [5 x i8] c"rest\00" -@fld.str.893 = private constant [5 x i8] c"spec\00" -@fld.str.894 = private constant [7 x i8] c"values\00" -@field_names.895 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.888, i64 5 }, { ptr, i64 } { ptr @fld.str.889, i64 7 }, { ptr, i64 } { ptr @fld.str.890, i64 9 }, { ptr, i64 } { ptr @fld.str.891, i64 4 }, { ptr, i64 } { ptr @fld.str.892, i64 4 }, { ptr, i64 } { ptr @fld.str.893, i64 4 }, { ptr, i64 } { ptr @fld.str.894, i64 6 }] -@str.896 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.897 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.898 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.899 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.900 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.901 = private constant [2 x i8] c"h\00" -@fld.str.902 = private constant [4 x i8] c"buf\00" -@fld.str.903 = private constant [8 x i8] c"buf_len\00" -@fld.str.904 = private constant [10 x i8] c"total_len\00" -@field_names.905 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.901, i64 1 }, { ptr, i64 } { ptr @fld.str.902, i64 3 }, { ptr, i64 } { ptr @fld.str.903, i64 7 }, { ptr, i64 } { ptr @fld.str.904, i64 9 }] -@str.906 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.907 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 -@str.908 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.909 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.910 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.911 = private constant [5 x i8] c"data\00" -@field_names.912 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.911, i64 4 }] -@str.913 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.914 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 -@str.915 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.916 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.917 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.918 = private constant [2 x i8] c"x\00" -@fld.str.919 = private constant [2 x i8] c"y\00" -@field_names.920 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.918, i64 1 }, { ptr, i64 } { ptr @fld.str.919, i64 1 }] -@str.921 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.922 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 -@str.923 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.924 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.925 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.926 = private constant [2 x i8] c"x\00" -@fld.str.927 = private constant [2 x i8] c"y\00" -@field_names.928 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.926, i64 1 }, { ptr, i64 } { ptr @fld.str.927, i64 1 }] -@str.929 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.930 = private unnamed_addr constant [11 x i8] c"Shape.rect\00", align 1 -@str.931 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.932 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.933 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.934 = private constant [2 x i8] c"w\00" -@fld.str.935 = private constant [2 x i8] c"h\00" -@field_names.936 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.934, i64 1 }, { ptr, i64 } { ptr @fld.str.935, i64 1 }] -@str.937 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.938 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.939 = private constant [5 x i8] c"read\00" -@fld.str.940 = private constant [6 x i8] c"write\00" -@fld.str.941 = private constant [7 x i8] c"append\00" -@fld.str.942 = private constant [11 x i8] c"read_write\00" -@field_names.943 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.939, i64 4 }, { ptr, i64 } { ptr @fld.str.940, i64 5 }, { ptr, i64 } { ptr @fld.str.941, i64 6 }, { ptr, i64 } { ptr @fld.str.942, i64 10 }] -@str.944 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.945 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.946 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.947 = private constant [4 x i8] c"set\00" -@fld.str.948 = private constant [8 x i8] c"current\00" -@fld.str.949 = private constant [4 x i8] c"end\00" -@field_names.950 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.947, i64 3 }, { ptr, i64 } { ptr @fld.str.948, i64 7 }, { ptr, i64 } { ptr @fld.str.949, i64 3 }] -@str.951 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.952 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.953 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.954 = private constant [6 x i8] c"null_\00" -@fld.str.955 = private constant [6 x i8] c"bool_\00" -@fld.str.956 = private constant [5 x i8] c"int_\00" -@fld.str.957 = private constant [4 x i8] c"str\00" -@fld.str.958 = private constant [6 x i8] c"array\00" -@fld.str.959 = private constant [7 x i8] c"object\00" -@field_names.960 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.954, i64 5 }, { ptr, i64 } { ptr @fld.str.955, i64 5 }, { ptr, i64 } { ptr @fld.str.956, i64 4 }, { ptr, i64 } { ptr @fld.str.957, i64 3 }, { ptr, i64 } { ptr @fld.str.958, i64 5 }, { ptr, i64 } { ptr @fld.str.959, i64 6 }] -@str.961 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.962 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.963 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.964 = private constant [6 x i8] c"macos\00" -@fld.str.965 = private constant [6 x i8] c"linux\00" -@fld.str.966 = private constant [8 x i8] c"windows\00" -@fld.str.967 = private constant [5 x i8] c"wasm\00" -@fld.str.968 = private constant [4 x i8] c"ios\00" -@fld.str.969 = private constant [8 x i8] c"android\00" -@fld.str.970 = private constant [8 x i8] c"unknown\00" -@field_names.971 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.964, i64 5 }, { ptr, i64 } { ptr @fld.str.965, i64 5 }, { ptr, i64 } { ptr @fld.str.966, i64 7 }, { ptr, i64 } { ptr @fld.str.967, i64 4 }, { ptr, i64 } { ptr @fld.str.968, i64 3 }, { ptr, i64 } { ptr @fld.str.969, i64 7 }, { ptr, i64 } { ptr @fld.str.970, i64 7 }] -@str.972 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.973 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.974 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.975 = private constant [8 x i8] c"aarch64\00" -@fld.str.976 = private constant [7 x i8] c"x86_64\00" -@fld.str.977 = private constant [7 x i8] c"wasm32\00" -@fld.str.978 = private constant [7 x i8] c"wasm64\00" -@fld.str.979 = private constant [8 x i8] c"unknown\00" -@field_names.980 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.975, i64 7 }, { ptr, i64 } { ptr @fld.str.976, i64 6 }, { ptr, i64 } { ptr @fld.str.977, i64 6 }, { ptr, i64 } { ptr @fld.str.978, i64 6 }, { ptr, i64 } { ptr @fld.str.979, i64 7 }] -@str.981 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.982 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.983 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.984 = private constant [7 x i8] c"circle\00" -@fld.str.985 = private constant [5 x i8] c"rect\00" -@fld.str.986 = private constant [5 x i8] c"none\00" -@field_names.987 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.984, i64 6 }, { ptr, i64 } { ptr @fld.str.985, i64 4 }, { ptr, i64 } { ptr @fld.str.986, i64 4 }] -@str.988 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.989 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.990 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.991 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.992 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.993 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.994 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.995 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.996 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.997 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.998 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.999 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1000 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1001 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1002 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1003 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1004 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1005 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1006 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1007 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1008 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1009 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1010 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1011 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1012 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1013 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1014 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1015 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1016 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1017 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1018 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1019 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1020 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1021 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1022 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1023 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1024 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1025 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1026 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1027 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1028 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1029 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1030 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.1031 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1032 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1033 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.1034 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1035 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1036 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.1037 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1038 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1039 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.1040 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1041 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1042 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.1043 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1044 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1045 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.1046 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1047 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1048 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.1049 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1050 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1051 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.1052 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1053 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1054 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.1055 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1056 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1057 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.1058 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1059 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1060 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.1061 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1062 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1063 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.1064 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1065 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1066 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.1067 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1068 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1069 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.1070 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1071 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1072 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.1073 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1074 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1075 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.1076 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1077 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1078 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.1079 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1080 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1081 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.1082 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1083 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1084 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.1085 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1086 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1087 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.1088 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1089 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1090 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.1091 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1092 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1093 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.1094 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1095 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1096 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.1097 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1098 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1099 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.1100 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1101 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1102 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.1103 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1104 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1105 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.1106 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1107 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1108 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.1109 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1110 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1111 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.1112 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1113 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1114 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.1115 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1116 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1117 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 -@str.1118 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1119 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1120 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 -@str.1121 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1122 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1123 = private unnamed_addr constant [7 x i8] c"*Shape\00", align 1 -@str.1124 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1125 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1126 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.1127 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1128 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1129 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.698 = private constant [5 x i8] c"line\00" +@fld.str.699 = private constant [4 x i8] c"col\00" +@fld.str.700 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.698, i64 4 }, { ptr, i64 } { ptr @fld.str.699, i64 3 }, { ptr, i64 } { ptr @fld.str.700, i64 4 }] +@str.701 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.702 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.703 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.704 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.705 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.706 = private constant [4 x i8] c"ctx\00" +@fld.str.707 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.708 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.709 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.706, i64 3 }, { ptr, i64 } { ptr @fld.str.707, i64 11 }, { ptr, i64 } { ptr @fld.str.708, i64 13 }] +@str.710 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.711 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.712 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.713 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.714 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.715 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.716 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.718 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.719 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.720 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.721 = private constant [12 x i8] c"alloc_count\00" +@field_names.722 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.721, i64 11 }] +@str.723 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.724 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.725 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.726 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.727 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.728 = private constant [5 x i8] c"next\00" +@fld.str.729 = private constant [4 x i8] c"cap\00" +@field_names.730 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.728, i64 4 }, { ptr, i64 } { ptr @fld.str.729, i64 3 }] +@str.731 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.732 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.733 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.734 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.735 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.736 = private constant [6 x i8] c"first\00" +@fld.str.737 = private constant [10 x i8] c"end_index\00" +@fld.str.738 = private constant [7 x i8] c"parent\00" +@field_names.739 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.736, i64 5 }, { ptr, i64 } { ptr @fld.str.737, i64 9 }, { ptr, i64 } { ptr @fld.str.738, i64 6 }] +@str.740 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.741 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.742 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.743 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.744 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.745 = private constant [4 x i8] c"buf\00" +@fld.str.746 = private constant [4 x i8] c"len\00" +@fld.str.747 = private constant [4 x i8] c"pos\00" +@field_names.748 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.745, i64 3 }, { ptr, i64 } { ptr @fld.str.746, i64 3 }, { ptr, i64 } { ptr @fld.str.747, i64 3 }] +@str.749 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.750 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.751 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.752 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.753 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.754 = private constant [7 x i8] c"parent\00" +@fld.str.755 = private constant [12 x i8] c"alloc_count\00" +@fld.str.756 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.757 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.758 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.754, i64 6 }, { ptr, i64 } { ptr @fld.str.755, i64 11 }, { ptr, i64 } { ptr @fld.str.756, i64 13 }, { ptr, i64 } { ptr @fld.str.757, i64 17 }] +@str.759 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.760 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.761 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.762 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.763 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.764 = private constant [10 x i8] c"allocator\00" +@fld.str.765 = private constant [5 x i8] c"data\00" +@field_names.766 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.764, i64 9 }, { ptr, i64 } { ptr @fld.str.765, i64 4 }] +@str.767 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.768 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.769 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.770 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.771 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.772 = private constant [3 x i8] c"fd\00" +@field_names.773 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.772, i64 2 }] +@str.774 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.775 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.776 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.777 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.778 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.779 = private constant [5 x i8] c"file\00" +@fld.str.780 = private constant [5 x i8] c"line\00" +@fld.str.781 = private constant [4 x i8] c"col\00" +@fld.str.782 = private constant [5 x i8] c"func\00" +@fld.str.783 = private constant [10 x i8] c"line_text\00" +@field_names.784 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.779, i64 4 }, { ptr, i64 } { ptr @fld.str.780, i64 4 }, { ptr, i64 } { ptr @fld.str.781, i64 3 }, { ptr, i64 } { ptr @fld.str.782, i64 4 }, { ptr, i64 } { ptr @fld.str.783, i64 9 }] +@str.785 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.786 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.787 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.788 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.789 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.790 = private constant [10 x i8] c"exit_code\00" +@fld.str.791 = private constant [7 x i8] c"stdout\00" +@field_names.792 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.790, i64 9 }, { ptr, i64 } { ptr @fld.str.791, i64 6 }] +@str.793 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.794 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.795 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.796 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.797 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.798 = private constant [8 x i8] c"sin_len\00" +@fld.str.799 = private constant [11 x i8] c"sin_family\00" +@fld.str.800 = private constant [9 x i8] c"sin_port\00" +@fld.str.801 = private constant [9 x i8] c"sin_addr\00" +@fld.str.802 = private constant [9 x i8] c"sin_zero\00" +@field_names.803 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.798, i64 7 }, { ptr, i64 } { ptr @fld.str.799, i64 10 }, { ptr, i64 } { ptr @fld.str.800, i64 8 }, { ptr, i64 } { ptr @fld.str.801, i64 8 }, { ptr, i64 } { ptr @fld.str.802, i64 8 }] +@str.804 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.805 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.806 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.807 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.808 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.809 = private constant [6 x i8] c"items\00" +@fld.str.810 = private constant [4 x i8] c"len\00" +@fld.str.811 = private constant [4 x i8] c"cap\00" +@field_names.812 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.809, i64 5 }, { ptr, i64 } { ptr @fld.str.810, i64 3 }, { ptr, i64 } { ptr @fld.str.811, i64 3 }] +@str.813 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.814 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.815 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.816 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.817 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.818 = private constant [6 x i8] c"items\00" +@fld.str.819 = private constant [4 x i8] c"len\00" +@fld.str.820 = private constant [4 x i8] c"cap\00" +@field_names.821 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.818, i64 5 }, { ptr, i64 } { ptr @fld.str.819, i64 3 }, { ptr, i64 } { ptr @fld.str.820, i64 3 }] +@str.822 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.823 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.824 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.825 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.826 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.827 = private constant [4 x i8] c"key\00" +@fld.str.828 = private constant [4 x i8] c"val\00" +@field_names.829 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.827, i64 3 }, { ptr, i64 } { ptr @fld.str.828, i64 3 }] +@str.830 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.831 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.832 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.833 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.834 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.835 = private constant [4 x i8] c"dst\00" +@fld.str.836 = private constant [4 x i8] c"pos\00" +@fld.str.837 = private constant [5 x i8] c"file\00" +@field_names.838 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.835, i64 3 }, { ptr, i64 } { ptr @fld.str.836, i64 3 }, { ptr, i64 } { ptr @fld.str.837, i64 4 }] +@str.839 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.840 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.841 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.842 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.843 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.844 = private constant [4 x i8] c"src\00" +@fld.str.845 = private constant [4 x i8] c"pos\00" +@fld.str.846 = private constant [6 x i8] c"alloc\00" +@field_names.847 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.844, i64 3 }, { ptr, i64 } { ptr @fld.str.845, i64 3 }, { ptr, i64 } { ptr @fld.str.846, i64 5 }] +@str.848 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.849 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.850 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.851 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.852 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.853 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.854 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.855 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.856 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.857 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.858 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.859 = private constant [5 x i8] c"name\00" +@fld.str.860 = private constant [12 x i8] c"takes_value\00" +@fld.str.861 = private constant [9 x i8] c"required\00" +@field_names.862 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.859, i64 4 }, { ptr, i64 } { ptr @fld.str.860, i64 11 }, { ptr, i64 } { ptr @fld.str.861, i64 8 }] +@str.863 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.864 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.865 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.866 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.867 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.868 = private constant [6 x i8] c"group\00" +@fld.str.869 = private constant [8 x i8] c"command\00" +@fld.str.870 = private constant [6 x i8] c"flags\00" +@field_names.871 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.868, i64 5 }, { ptr, i64 } { ptr @fld.str.869, i64 7 }, { ptr, i64 } { ptr @fld.str.870, i64 5 }] +@str.872 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.873 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.874 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.875 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.876 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.877 = private constant [4 x i8] c"set\00" +@fld.str.878 = private constant [6 x i8] c"value\00" +@field_names.879 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.877, i64 3 }, { ptr, i64 } { ptr @fld.str.878, i64 5 }] +@str.880 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.881 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.882 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.883 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.884 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.885 = private constant [6 x i8] c"index\00" +@fld.str.886 = private constant [6 x i8] c"token\00" +@field_names.887 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.885, i64 5 }, { ptr, i64 } { ptr @fld.str.886, i64 5 }] +@str.888 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.889 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.890 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.891 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.892 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.893 = private constant [6 x i8] c"group\00" +@fld.str.894 = private constant [8 x i8] c"command\00" +@fld.str.895 = private constant [10 x i8] c"cmd_index\00" +@fld.str.896 = private constant [5 x i8] c"json\00" +@fld.str.897 = private constant [5 x i8] c"rest\00" +@fld.str.898 = private constant [5 x i8] c"spec\00" +@fld.str.899 = private constant [7 x i8] c"values\00" +@field_names.900 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.893, i64 5 }, { ptr, i64 } { ptr @fld.str.894, i64 7 }, { ptr, i64 } { ptr @fld.str.895, i64 9 }, { ptr, i64 } { ptr @fld.str.896, i64 4 }, { ptr, i64 } { ptr @fld.str.897, i64 4 }, { ptr, i64 } { ptr @fld.str.898, i64 4 }, { ptr, i64 } { ptr @fld.str.899, i64 6 }] +@str.901 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.902 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.903 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.904 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.905 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.906 = private constant [2 x i8] c"h\00" +@fld.str.907 = private constant [4 x i8] c"buf\00" +@fld.str.908 = private constant [8 x i8] c"buf_len\00" +@fld.str.909 = private constant [10 x i8] c"total_len\00" +@field_names.910 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.906, i64 1 }, { ptr, i64 } { ptr @fld.str.907, i64 3 }, { ptr, i64 } { ptr @fld.str.908, i64 7 }, { ptr, i64 } { ptr @fld.str.909, i64 9 }] +@str.911 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.912 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.913 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.914 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.915 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.916 = private constant [5 x i8] c"data\00" +@field_names.917 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.916, i64 4 }] +@str.918 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.919 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.920 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.921 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.922 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.923 = private constant [2 x i8] c"x\00" +@fld.str.924 = private constant [2 x i8] c"y\00" +@field_names.925 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.923, i64 1 }, { ptr, i64 } { ptr @fld.str.924, i64 1 }] +@str.926 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.927 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.928 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.929 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.930 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.931 = private constant [2 x i8] c"x\00" +@fld.str.932 = private constant [2 x i8] c"y\00" +@field_names.933 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.931, i64 1 }, { ptr, i64 } { ptr @fld.str.932, i64 1 }] +@str.934 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.935 = private unnamed_addr constant [11 x i8] c"Shape.rect\00", align 1 +@str.936 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.937 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.938 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.939 = private constant [2 x i8] c"w\00" +@fld.str.940 = private constant [2 x i8] c"h\00" +@field_names.941 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.939, i64 1 }, { ptr, i64 } { ptr @fld.str.940, i64 1 }] +@str.942 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.943 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.944 = private constant [5 x i8] c"read\00" +@fld.str.945 = private constant [6 x i8] c"write\00" +@fld.str.946 = private constant [7 x i8] c"append\00" +@fld.str.947 = private constant [11 x i8] c"read_write\00" +@field_names.948 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.944, i64 4 }, { ptr, i64 } { ptr @fld.str.945, i64 5 }, { ptr, i64 } { ptr @fld.str.946, i64 6 }, { ptr, i64 } { ptr @fld.str.947, i64 10 }] +@str.949 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.950 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.951 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.952 = private constant [4 x i8] c"set\00" +@fld.str.953 = private constant [8 x i8] c"current\00" +@fld.str.954 = private constant [4 x i8] c"end\00" +@field_names.955 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.952, i64 3 }, { ptr, i64 } { ptr @fld.str.953, i64 7 }, { ptr, i64 } { ptr @fld.str.954, i64 3 }] +@str.956 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.957 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.958 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.959 = private constant [6 x i8] c"null_\00" +@fld.str.960 = private constant [6 x i8] c"bool_\00" +@fld.str.961 = private constant [5 x i8] c"int_\00" +@fld.str.962 = private constant [4 x i8] c"str\00" +@fld.str.963 = private constant [6 x i8] c"array\00" +@fld.str.964 = private constant [7 x i8] c"object\00" +@field_names.965 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.959, i64 5 }, { ptr, i64 } { ptr @fld.str.960, i64 5 }, { ptr, i64 } { ptr @fld.str.961, i64 4 }, { ptr, i64 } { ptr @fld.str.962, i64 3 }, { ptr, i64 } { ptr @fld.str.963, i64 5 }, { ptr, i64 } { ptr @fld.str.964, i64 6 }] +@str.966 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.967 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.968 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.969 = private constant [6 x i8] c"macos\00" +@fld.str.970 = private constant [6 x i8] c"linux\00" +@fld.str.971 = private constant [8 x i8] c"windows\00" +@fld.str.972 = private constant [5 x i8] c"wasm\00" +@fld.str.973 = private constant [4 x i8] c"ios\00" +@fld.str.974 = private constant [8 x i8] c"android\00" +@fld.str.975 = private constant [8 x i8] c"unknown\00" +@field_names.976 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.969, i64 5 }, { ptr, i64 } { ptr @fld.str.970, i64 5 }, { ptr, i64 } { ptr @fld.str.971, i64 7 }, { ptr, i64 } { ptr @fld.str.972, i64 4 }, { ptr, i64 } { ptr @fld.str.973, i64 3 }, { ptr, i64 } { ptr @fld.str.974, i64 7 }, { ptr, i64 } { ptr @fld.str.975, i64 7 }] +@str.977 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.978 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.979 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.980 = private constant [8 x i8] c"aarch64\00" +@fld.str.981 = private constant [7 x i8] c"x86_64\00" +@fld.str.982 = private constant [7 x i8] c"wasm32\00" +@fld.str.983 = private constant [7 x i8] c"wasm64\00" +@fld.str.984 = private constant [8 x i8] c"unknown\00" +@field_names.985 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.980, i64 7 }, { ptr, i64 } { ptr @fld.str.981, i64 6 }, { ptr, i64 } { ptr @fld.str.982, i64 6 }, { ptr, i64 } { ptr @fld.str.983, i64 6 }, { ptr, i64 } { ptr @fld.str.984, i64 7 }] +@str.986 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.987 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.988 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.989 = private constant [7 x i8] c"circle\00" +@fld.str.990 = private constant [5 x i8] c"rect\00" +@fld.str.991 = private constant [5 x i8] c"none\00" +@field_names.992 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.989, i64 6 }, { ptr, i64 } { ptr @fld.str.990, i64 4 }, { ptr, i64 } { ptr @fld.str.991, i64 4 }] +@str.993 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.994 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.995 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.996 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.997 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.998 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.999 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1000 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1001 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1002 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1003 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1004 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1005 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1006 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1007 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1008 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1009 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1010 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1011 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1012 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1013 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1014 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1015 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1016 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1017 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1018 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1019 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1020 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1021 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1022 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1023 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1024 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1025 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1026 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1027 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1028 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1029 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1030 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1031 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1032 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1033 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1034 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1035 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.1036 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1037 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1038 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.1039 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1040 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1041 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.1042 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1043 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1044 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.1045 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1046 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1047 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.1048 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1049 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1050 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.1051 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1052 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1053 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.1054 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1055 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1056 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.1057 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1058 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1059 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.1060 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1061 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1062 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.1063 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1064 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1065 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.1066 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1067 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1068 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.1069 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1070 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1071 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.1072 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1073 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1074 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.1075 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1076 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1077 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.1078 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1079 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1080 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.1081 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1082 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1083 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.1084 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1085 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1086 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.1087 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1088 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1089 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.1090 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1091 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1092 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.1093 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1094 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1095 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.1096 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1097 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1098 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.1099 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1100 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1101 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.1102 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1103 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1104 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.1105 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1106 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1107 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.1108 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1109 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1110 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.1111 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1112 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1113 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.1114 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1115 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1116 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.1117 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1118 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1119 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.1120 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1121 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1122 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 +@str.1123 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1124 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1125 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 +@str.1126 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1127 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1128 = private unnamed_addr constant [7 x i8] c"*Shape\00", align 1 +@str.1129 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.1130 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1131 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1131 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.1132 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1133 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1134 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1135 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1136 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -687,6 +687,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -906,7 +909,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.465, i64 1 } + ret { ptr, i64 } { ptr @str.470, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1033,7 +1036,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.466, i64 4 }, %if.then.78 ], [ { ptr @str.467, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.471, i64 4 }, %if.then.78 ], [ { ptr @str.472, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1367,7 +1370,7 @@ entry: br i1 %icmp, label %if.then.410, label %if.merge.411 if.then.410: ; preds = %entry - ret { ptr, i64 } { ptr @str.468, i64 1 } + ret { ptr, i64 } { ptr @str.473, i64 1 } if.merge.411: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1517,7 +1520,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.469, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.474, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1543,9 +1546,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1593,9 +1596,9 @@ entry: i64 85, label %match.arm.48 i64 102, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1637,7 +1640,7 @@ match.merge.37: ; preds = %dispatch.merge.519, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.470, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.475, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1681,9 +1684,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1771,9 +1774,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.373 [ i64 18, label %dispatch.case.374 - i64 21, label %dispatch.case.375 - i64 23, label %dispatch.case.376 - i64 25, label %dispatch.case.377 + i64 22, label %dispatch.case.375 + i64 24, label %dispatch.case.376 + i64 26, label %dispatch.case.377 i64 28, label %dispatch.case.378 i64 29, label %dispatch.case.379 i64 31, label %dispatch.case.380 @@ -1873,7 +1876,7 @@ dispatch.merge.94: ; preds = %dispatch.case.124, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.659, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.664, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1887,32 +1890,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2114,7 +2117,7 @@ dispatch.merge.270: ; preds = %dispatch.case.277, br label %match.merge.37 dispatch.default.271: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.660, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.665, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.270 dispatch.case.272: ; preds = %match.arm.44 @@ -2163,7 +2166,7 @@ dispatch.merge.290: ; preds = %dispatch.case.299, br label %match.merge.37 dispatch.default.291: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.661, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.666, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.290 dispatch.case.292: ; preds = %match.arm.47 @@ -2236,7 +2239,7 @@ dispatch.merge.340: ; preds = %dispatch.case.346, br label %match.merge.37 dispatch.default.341: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.662, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.667, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.340 dispatch.case.342: ; preds = %match.arm.48 @@ -2285,7 +2288,7 @@ dispatch.merge.372: ; preds = %dispatch.case.406, br label %match.merge.37 dispatch.default.373: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.663, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.668, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.372 dispatch.case.374: ; preds = %match.arm.49 @@ -2525,7 +2528,7 @@ dispatch.merge.519: ; preds = %dispatch.case.524, br label %match.merge.37 dispatch.default.520: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.664, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.669, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.519 dispatch.case.521: ; preds = %match.arm.50 @@ -2567,7 +2570,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.665, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.670, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2663,7 +2666,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2671,7 +2674,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2681,13 +2684,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2695,7 +2698,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2709,7 +2712,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2717,7 +2720,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2728,7 +2731,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2785,7 +2788,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2793,7 +2796,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2804,7 +2807,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2824,7 +2827,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2832,7 +2835,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, 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 @@ -2843,7 +2846,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2853,64 +2856,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3086,163 +3092,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3440,64 +3449,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3527,97 +3536,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3656,7 +3665,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3725,1024 +3734,1033 @@ declare { float, float } @Vec2.negate(ptr, { float, float }) #0 declare i1 @Vec2.equals(ptr, { float, float }, { float, float }) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind -declare void @assert.162(ptr, i1) #0 +declare void @assert.164(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.163(ptr) #0 +declare void @out.165(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.164(ptr, ptr, i64) #0 +declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.165(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.166(ptr) #0 +declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.167(ptr, ptr, i64) #0 +declare i64 @GPA.init.169(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.169(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.170(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.171(ptr, ptr) #0 +declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.172(ptr, ptr) #0 +declare void @Arena.reset.174(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.173(ptr, ptr, i64) #0 +declare void @Arena.deinit.175(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.174(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.175(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.176(ptr, ptr) #0 +declare ptr @BufAlloc.init.178(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.177(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.178(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.179(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.180(ptr, ptr) #0 +declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.181(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.182(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.184(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.183(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @cstring.184(ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.185(ptr, i64) #0 +declare ptr @cstring.187(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.186(ptr, i64) #0 +declare ptr @int_to_string.188(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.187(ptr, i1) #0 +declare ptr @uint_to_string.189(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.188(ptr, double) #0 +declare ptr @bool_to_string.190(ptr, i1) #0 ; Function Attrs: nounwind -declare void @hex_group.189(ptr, ptr, i64, i64) #0 +declare ptr @float_to_string.191(ptr, double) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.190(ptr, i64) #0 +declare void @hex_group.192(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.191(ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @concat.192(ptr, ptr, ptr) #0 +declare ptr @int_to_hex_string.194(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.193(ptr, ptr, i64, i64) #0 +declare ptr @concat.195(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.194(ptr, ptr) #0 +declare ptr @substr.196(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.195(ptr, [2 x i64]) #0 +declare ptr @path_join.197(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.196(ptr, ptr) #0 +declare ptr @any_to_string.198(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.197(ptr, ptr, i64) #0 +declare ptr @build_format.199(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.198(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.199(ptr) #0 +declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.200(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.201(ptr, ptr, ptr) #0 +declare i64 @GPA.init.203(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.202(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.203(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.204(ptr, ptr) #0 +declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.205(ptr, ptr) #0 +declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.206(ptr, ptr, i64) #0 +declare void @Arena.reset.208(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.207(ptr, ptr, ptr) #0 +declare void @Arena.deinit.209(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.208(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.209(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.210(ptr, ptr, i64) #0 +declare ptr @BufAlloc.init.212(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.212(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.213(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.214(ptr, ptr) #0 +declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.215(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.216(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.218(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.217(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.218(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.219(ptr, i32, ...) #0 +declare ptr @escape.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.220(i32) #0 +declare void @log_emit.222(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.221(i32, ptr, i64) #0 +declare i32 @open.223(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.222(i32, i64, i32) #0 +declare i32 @close.224(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.223(ptr) #0 +declare i64 @read.225(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.224(ptr) #0 +declare i64 @lseek.226(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.225(ptr, i32) #0 +declare i32 @unlink.227(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.226(ptr, i32) #0 +declare i32 @rmdir.228(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.227(ptr, i32) #0 +declare i32 @mkdir.229(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.228(ptr, ptr) #0 +declare i32 @access.230(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.229(ptr, ptr) #0 +declare i32 @chmod.231(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.230(ptr, ptr) #0 +declare i32 @rename.232(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.231(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.233(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.232(ptr, ptr, ptr) #0 +declare i1 @File.close.234(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.233(ptr, ptr, i64, i64) #0 +declare i64 @File.read.235(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.234(ptr, i64) #0 +declare i64 @File.write.236(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.235(ptr, ptr, i64) #0 +declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.236(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.238(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.237(ptr, ptr, ptr) #0 +declare i64 @open_file.239(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.238(ptr, ptr, ptr) #0 +declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.239(ptr, ptr) #0 +declare i1 @write_file.241(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.240(ptr, ptr) #0 +declare i1 @append_file.242(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.241(ptr, ptr) #0 +declare i1 @exists.243(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.242(ptr, ptr) #0 +declare i1 @delete_file.244(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.243(ptr, ptr, i32) #0 +declare i1 @delete_dir.245(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.244(ptr, ptr, ptr) #0 +declare i1 @create_dir.246(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.245(ptr, ptr) #0 +declare i1 @set_mode.247(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.246(ptr, ptr, ptr) #0 +declare i1 @move.248(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.247(ptr, ptr) #0 +declare i1 @create_dir_all.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.248(ptr, ptr) #0 +declare i1 @copy_file.250(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.249(ptr, i32) #0 +declare ptr @basename.251(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.250() #0 +declare ptr @dirname.252(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.251() #0 +declare ptr @spaces.253(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.252(i32) #0 +declare i32 @sx_trace_len.254() #0 ; Function Attrs: nounwind -declare ptr @to_string.253(ptr) #0 +declare i32 @sx_trace_truncated.255() #0 ; Function Attrs: nounwind -declare void @print_current.254(ptr) #0 +declare i64 @sx_trace_frame_at.256(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.255(ptr) #0 +declare ptr @to_string.257(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.256(ptr, ptr) #0 +declare void @print_current.258(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.257(ptr) #0 +declare void @print_interpreter_frames.259(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.258(ptr, i64, i64, ptr) #0 +declare ptr @popen.260(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.259(ptr) #0 +declare i32 @pclose.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.260(ptr) #0 +declare i64 @fread.262(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.261(ptr) #0 +declare i32 @feof.263(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.262(ptr) #0 +declare ptr @getenv.264(ptr) #0 ; Function Attrs: nounwind -declare void @run.263(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.265(ptr) #0 ; Function Attrs: nounwind -declare void @env.264(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.266(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.265(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.266(i32) #0 +declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.267(ptr, i8, ptr) #0 +declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.268(ptr, i1, ptr, ptr) #0 +declare void @_exit.270(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.269(i32, i32, i32) #0 +declare void @exit.271(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.270(i32, i32, i32, ptr, i32) #0 +declare void @assert.272(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.271(i32, ptr, i32) #0 +declare i32 @socket.273(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.272(i32, i32) #0 +declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.273(i32, ptr, ptr) #0 +declare i32 @bind.275(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.274(i32, ptr, i64) #0 +declare i32 @listen.276(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.275(i32) #0 +declare i32 @accept.277(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.276(ptr, i64) #0 +declare i64 @read.278(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.277(ptr, ptr, i64) #0 +declare i32 @close.279(i32) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.278(ptr, ptr, ptr) #0 +declare i16 @htons.280(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.279(ptr) #0 +declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.280(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.281(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.282(ptr, ptr, i64) #0 +declare i64 @GPA.init.284(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.283(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.284(ptr, ptr) #0 +declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.285(ptr, ptr) #0 +declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.286(ptr, ptr, i64) #0 +declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.287(ptr, ptr, ptr) #0 +declare void @Arena.reset.289(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.288(ptr, ptr, i64) #0 +declare void @Arena.deinit.290(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.289(ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.290(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.291(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.init.293(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.292(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.reset.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.293(ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.294(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.297(ptr, i32, ...) #0 +declare void @TrackingAllocator.report.299(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.298(i32) #0 +declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @read.299(i32, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.300(i32, i64, i32) #0 +declare i32 @open.302(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.301(ptr) #0 +declare i32 @close.303(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.302(ptr) #0 +declare i64 @read.304(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.303(ptr, i32) #0 +declare i64 @lseek.305(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.304(ptr, i32) #0 +declare i32 @unlink.306(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.305(ptr, i32) #0 +declare i32 @rmdir.307(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.306(ptr, ptr) #0 +declare i32 @mkdir.308(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.307(ptr, ptr) #0 +declare i32 @access.309(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.308(ptr, ptr) #0 +declare i32 @chmod.310(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.309(ptr, ptr, ptr) #0 +declare i32 @rename.311(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.310(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.312(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.311(ptr, ptr, i64, i64) #0 +declare i1 @File.close.313(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.312(ptr, i64) #0 +declare i64 @File.read.314(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.313(ptr, ptr, i64) #0 +declare i64 @File.write.315(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.314(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.315(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.317(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.316(ptr, ptr, ptr) #0 +declare i64 @open_file.318(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.317(ptr, ptr) #0 +declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.318(ptr, ptr) #0 +declare i1 @write_file.320(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.319(ptr, ptr) #0 +declare i1 @append_file.321(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.320(ptr, ptr) #0 +declare i1 @exists.322(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.321(ptr, ptr, i32) #0 +declare i1 @delete_file.323(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.322(ptr, ptr, ptr) #0 +declare i1 @delete_dir.324(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.323(ptr, ptr) #0 +declare i1 @create_dir.325(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.324(ptr, ptr, ptr) #0 +declare i1 @set_mode.326(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.325(ptr, ptr) #0 +declare i1 @move.327(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.326(ptr, ptr) #0 +declare i1 @create_dir_all.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.327(ptr, ptr, ptr, ptr) #0 +declare i1 @copy_file.329(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.328(ptr, ptr, ptr) #0 +declare ptr @basename.330(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.329(ptr, ptr, ptr, ptr, ptr) #0 +declare ptr @dirname.331(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.330(ptr, ptr, ptr) #0 +declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.331(ptr, ptr, i8) #0 +declare void @Array.deinit.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.332(ptr, ptr, ptr) #0 +declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.333(ptr, ptr) #0 +declare void @Object.deinit.335(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.334(ptr, i64) #0 +declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.335(ptr, i8, ptr) #0 +declare i32 @Sink.put.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.336(ptr, ptr, ptr) #0 +declare i32 @Sink.flush.338(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_int.337(ptr, i64, ptr) #0 +declare i8 @hex_digit.339(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_value.338(ptr, ptr, ptr) #0 +declare i32 @write_u_escape.340(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.339(ptr, ptr, ptr) #0 +declare i32 @write_string.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.340(ptr, ptr, ptr) #0 +declare i32 @write_int.342(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.341(ptr, ptr, ptr) #0 +declare i32 @write_value.343(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.342(ptr, ptr, ptr, ptr) #0 +declare i32 @write_array.344(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.343(ptr, i8) #0 +declare i32 @write_object.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.344(ptr, i64, ptr) #0 +declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.345(ptr, ptr) #0 +declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.346(ptr, ptr, ptr) #0 +declare [2 x i64] @hex_value.348(ptr, i8) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.347(ptr, ptr, i64, i64) #0 +declare i64 @encode_utf8.349(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.348(ptr, ptr, i64, i64, ptr) #0 +declare void @Parser.skip_ws.350(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.349(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.350(ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.351(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.352(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.353(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.354(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.355(i64, ptr) #0 +declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.356(i64, ptr) #0 +declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.357(i64, ptr) #0 +declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.358(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.359(i64, ptr, ptr) #0 +declare void @BuildOptions.add_framework.361(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.360(i64) #0 +declare void @BuildOptions.set_output_path.362(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.361(i64, i64) #0 +declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.362(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.363(i64, ptr) #0 +declare i64 @BuildOptions.asset_dir_count.365(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.364(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.365(i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.366(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.367(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.368(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.370(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.369(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.370(i64) #0 +declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.371(i64) #0 +declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.372(i64) #0 +declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.373(i64) #0 +declare ptr @BuildOptions.bundle_path.375(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.374(i64) #0 +declare ptr @BuildOptions.bundle_id.376(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.375(i64) #0 +declare ptr @BuildOptions.codesign_identity.377(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.376(i64) #0 +declare ptr @BuildOptions.provisioning_profile.378(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.377(i64) #0 +declare ptr @BuildOptions.target_triple.379(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.378(i64) #0 +declare i1 @BuildOptions.is_macos.380(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.379(i64) #0 +declare i1 @BuildOptions.is_ios.381(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.380(i64) #0 +declare i1 @BuildOptions.is_ios_device.382(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.381(i64, i64) #0 +declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.382(i64) #0 +declare i1 @BuildOptions.is_android.384(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.383(i64, i64) #0 +declare i64 @BuildOptions.framework_count.385(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.384(i64, ptr) #0 +declare ptr @BuildOptions.framework_at.386(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.385(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.386(i64) #0 +declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.387(i64) #0 +declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.388(i64) #0 +declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.389(i64, i64) #0 +declare ptr @BuildOptions.manifest_path.391(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.390(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.392(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.391() #0 +declare i64 @BuildOptions.jni_main_count.393(i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.392(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.393() #0 +declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.394() #0 +declare i64 @build_options.396() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.395(i32) #0 +declare ptr @spaces.397(ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.396(ptr) #0 +declare i32 @sx_trace_len.398() #0 ; Function Attrs: nounwind -declare void @print_current.397(ptr) #0 +declare i32 @sx_trace_truncated.399() #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.398(ptr) #0 +declare i64 @sx_trace_frame_at.400(i32) #0 ; Function Attrs: nounwind -declare ptr @popen.399(ptr, ptr) #0 +declare ptr @to_string.401(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.400(ptr) #0 +declare void @print_current.402(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.401(ptr, i64, i64, ptr) #0 +declare void @print_interpreter_frames.403(ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.402(ptr) #0 +declare ptr @popen.404(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.403(ptr) #0 +declare i32 @pclose.405(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.404(ptr) #0 +declare i64 @fread.406(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @system.405(ptr) #0 +declare i32 @feof.407(ptr) #0 ; Function Attrs: nounwind -declare void @run.406(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare ptr @getenv.408(ptr) #0 ; Function Attrs: nounwind -declare void @env.407(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @strlen.409(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.408(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.410(ptr) #0 ; Function Attrs: nounwind -declare void @_exit.409(i32) #0 +declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.410(ptr, i8, ptr) #0 +declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.411(ptr, i1, ptr, ptr) #0 +declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.412() #0 +declare void @_exit.414(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.413() #0 +declare void @exit.415(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.414(ptr) #0 +declare void @assert.416(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_usage.415(ptr) #0 +declare ptr @_NSGetArgv.417() #0 ; Function Attrs: nounwind -declare i64 @os_argc.416(ptr) #0 +declare ptr @_NSGetArgc.418() #0 ; Function Attrs: nounwind -declare ptr @os_args.417(ptr, ptr) #0 +declare void @exit_ok.419(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.418(ptr, ptr, ptr) #0 +declare void @exit_usage.420(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.419(ptr, ptr, ptr) #0 +declare i64 @os_argc.421(ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.420(ptr, ptr) #0 +declare ptr @os_args.422(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.421(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.422(ptr, i32, ...) #0 +declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.423(i32) #0 +declare i1 @is_long_flag.425(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.424(i32, ptr, i64) #0 +declare void @parse.426(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.425(i32, i64, i32) #0 +declare i32 @open.427(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.426(ptr) #0 +declare i32 @close.428(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.427(ptr) #0 +declare i64 @read.429(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.428(ptr, i32) #0 +declare i64 @lseek.430(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.429(ptr, i32) #0 +declare i32 @unlink.431(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.430(ptr, i32) #0 +declare i32 @rmdir.432(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.431(ptr, ptr) #0 +declare i32 @mkdir.433(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.432(ptr, ptr) #0 +declare i32 @access.434(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.433(ptr, ptr) #0 +declare i32 @chmod.435(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.434(ptr, ptr, ptr) #0 +declare i32 @rename.436(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.435(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.437(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.436(ptr, ptr, i64, i64) #0 +declare i1 @File.close.438(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.437(ptr, i64) #0 +declare i64 @File.read.439(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.438(ptr, ptr, i64) #0 +declare i64 @File.write.440(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.439(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.440(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.442(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.441(ptr, ptr, ptr) #0 +declare i64 @open_file.443(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.442(ptr, ptr) #0 +declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.443(ptr, ptr) #0 +declare i1 @write_file.445(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.444(ptr, ptr) #0 +declare i1 @append_file.446(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.445(ptr, ptr) #0 +declare i1 @exists.447(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.446(ptr, ptr, i32) #0 +declare i1 @delete_file.448(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.447(ptr, ptr, ptr) #0 +declare i1 @delete_dir.449(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.448(ptr, ptr) #0 +declare i1 @create_dir.450(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.449(ptr, ptr, ptr) #0 +declare i1 @set_mode.451(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.450(ptr, ptr) #0 +declare i1 @move.452(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.451(ptr, ptr) #0 +declare i1 @create_dir_all.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.452(ptr, i64, i64) #0 +declare i1 @copy_file.454(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.453(ptr, i64) #0 +declare ptr @basename.455(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.454(ptr, i64) #0 +declare ptr @dirname.456(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.455(ptr, i64) #0 +declare i64 @rotr.457(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.456(ptr, i64) #0 +declare i64 @big_sigma0.458(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.457(ptr, ptr) #0 +declare i64 @big_sigma1.459(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.458(ptr, ptr, ptr) #0 +declare i64 @small_sigma0.460(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.459(ptr, ptr) #0 +declare i64 @small_sigma1.461(ptr, i64) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.460(ptr, i64) #0 +declare void @Sha256.process_block.462(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.461(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare void @Sha256.update.463(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.462(ptr, ptr) #0 +declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @sha256_file.463(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare i8 @nibble_hex.465(ptr, i64) #0 ; Function Attrs: nounwind -declare void @assert.464(ptr, i1) #0 +declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 + +; Function Attrs: nounwind +declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.469(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4794,14 +4812,14 @@ entry: define internal void @print__ct_s4f0c3447f66dcf6d__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.680, i64 28 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.685, i64 28 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.681, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.686, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 28) @@ -4817,7 +4835,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.682, i64 28 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.687, i64 28 }) ret { ptr, i64 } %call } @@ -4831,7 +4849,7 @@ entry: define internal void @print__ct_s546acbc299164a0e__pack_s32_s32(ptr %0, i32 %1, i32 %2) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.683, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.688, i64 20 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca i32, align 4 @@ -4854,7 +4872,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 2, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.684, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.689, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 14) @@ -4894,7 +4912,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.685, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.690, i64 20 }) ret { ptr, i64 } %call } @@ -4914,7 +4932,7 @@ entry: define internal void @print__ct_scc8edc2d4140bd92__pack_Shape(ptr %0, { i64, [8 x i8] } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.686, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.691, i64 15 }, ptr %alloca, align 8 %allocaN = alloca { i64, [8 x i8] }, align 8 store { i64, [8 x i8] } %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4932,7 +4950,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.687, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.692, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -4962,7 +4980,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.688, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.693, i64 15 }) ret { ptr, i64 } %call } @@ -4973,7 +4991,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 15 }, { ptr, i64 } { ptr @str.690, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 15 }, { ptr, i64 } { ptr @str.695, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4992,12 +5010,12 @@ while.body.126: ; preds = %while.hdr.125 while.exit.127: ; preds = %while.hdr.125 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 1 }) ret { ptr, i64 } %callN if.then.128: ; preds = %while.body.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.129 @@ -5009,7 +5027,7 @@ if.merge.129: ; preds = %if.then.128, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.701, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5062,20 +5080,20 @@ fv.case24: ; preds = %if.merge.129 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 10 }, { ptr, i64 } { ptr @str.698, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 9 }, { ptr, i64 } { ptr @str.703, 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.130 -while.hdr.130: ; preds = %if.merge.134, %entry +while.hdr.130: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.131, label %while.exit.132 while.body.131: ; preds = %while.hdr.130 @@ -5085,224 +5103,24 @@ while.body.131: ; preds = %while.hdr.130 while.exit.132: ; preds = %while.hdr.130 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.699, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.704, i64 1 }) ret { ptr, i64 } %callN if.then.133: ; preds = %while.body.131 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.134 if.merge.134: ; preds = %if.then.133, %while.body.131 %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.701, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.709, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.702, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.130 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } { ptr @str.704, 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.135 - -while.hdr.135: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.136, label %while.exit.137 - -while.body.136: ; preds = %while.hdr.135 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.138, label %if.merge.139 - -while.exit.137: ; preds = %while.hdr.135 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 1 }) - ret { ptr, i64 } %callN - -if.then.138: ; preds = %while.body.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.139 - -if.merge.139: ; preds = %if.then.138, %while.body.136 - %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.708, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.135 - -fv.default: ; preds = %if.merge.139 - br label %fv.merge - -fv.case: ; preds = %if.merge.139 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 10 }, { ptr, i64 } { ptr @str.711, 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.140 - -while.hdr.140: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.141, label %while.exit.142 - -while.body.141: ; preds = %while.hdr.140 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.143, label %if.merge.144 - -while.exit.142: ; preds = %while.hdr.140 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 1 }) - ret { ptr, i64 } %callN - -if.then.143: ; preds = %while.body.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.144 - -if.merge.144: ; preds = %if.then.143, %while.body.141 - %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.716, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.717, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.140 - -fv.default: ; preds = %if.merge.144 - br label %fv.merge - -fv.case: ; preds = %if.merge.144 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.144 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 9 }, { ptr, i64 } { ptr @str.719, 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.145 - -while.hdr.145: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.146, label %while.exit.147 - -while.body.146: ; preds = %while.hdr.145 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.148, label %if.merge.149 - -while.exit.147: ; preds = %while.hdr.145 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.720, i64 1 }) - ret { ptr, i64 } %callN - -if.then.148: ; preds = %while.body.146 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.721, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.149 - -if.merge.149: ; preds = %if.then.148, %while.body.146 - %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.725, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.726, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.710, 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 @@ -5321,27 +5139,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.130 + +fv.default: ; preds = %if.merge.134 + br label %fv.merge + +fv.case: ; preds = %if.merge.134 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.134 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.134 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 10 }, { ptr, i64 } { ptr @str.712, 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.135 + +while.hdr.135: ; preds = %if.merge.139, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.136, label %while.exit.137 + +while.body.136: ; preds = %while.hdr.135 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.138, label %if.merge.139 + +while.exit.137: ; preds = %while.hdr.135 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, i64 1 }) + ret { ptr, i64 } %callN + +if.then.138: ; preds = %while.body.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.714, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.139 + +if.merge.139: ; preds = %if.then.138, %while.body.136 + %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.715, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.716, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.135 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } { ptr @str.718, 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.140 + +while.hdr.140: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.141, label %while.exit.142 + +while.body.141: ; preds = %while.hdr.140 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.143, label %if.merge.144 + +while.exit.142: ; preds = %while.hdr.140 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, i64 1 }) + ret { ptr, i64 } %callN + +if.then.143: ; preds = %while.body.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.720, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.144 + +if.merge.144: ; preds = %if.then.143, %while.body.141 + %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.722, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.140 + +fv.default: ; preds = %if.merge.144 + br label %fv.merge + +fv.case: ; preds = %if.merge.144 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 10 }, { ptr, i64 } { ptr @str.725, 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.145 + +while.hdr.145: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.146, label %while.exit.147 + +while.body.146: ; preds = %while.hdr.145 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.148, label %if.merge.149 + +while.exit.147: ; preds = %while.hdr.145 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.726, i64 1 }) + ret { ptr, i64 } %callN + +if.then.148: ; preds = %while.body.146 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.149 + +if.merge.149: ; preds = %if.then.148, %while.body.146 + %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.730, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.145 fv.default: ; preds = %if.merge.149 br label %fv.merge fv.case: ; preds = %if.merge.149 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.149 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.149 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -5351,7 +5369,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 5 }, { ptr, i64 } { ptr @str.728, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } { ptr @str.733, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5370,24 +5388,24 @@ while.body.151: ; preds = %while.hdr.150 while.exit.152: ; preds = %while.hdr.150 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.729, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.734, i64 1 }) ret { ptr, i64 } %callN if.then.153: ; preds = %while.body.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.730, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.735, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.154 if.merge.154: ; preds = %if.then.153, %while.body.151 %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.734, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.739, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.735, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, 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 @@ -5414,7 +5432,7 @@ fv.default: ; preds = %if.merge.154 fv.case: ; preds = %if.merge.154 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.154 @@ -5426,7 +5444,7 @@ fv.case20: ; preds = %if.merge.154 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -5435,7 +5453,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 8 }, { ptr, i64 } { ptr @str.737, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 8 }, { ptr, i64 } { ptr @str.742, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5454,24 +5472,24 @@ while.body.156: ; preds = %while.hdr.155 while.exit.157: ; preds = %while.hdr.155 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.738, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.743, i64 1 }) ret { ptr, i64 } %callN if.then.158: ; preds = %while.body.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.739, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.744, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.159 if.merge.159: ; preds = %if.then.158, %while.body.156 %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.743, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.748, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.744, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.749, 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 @@ -5518,7 +5536,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 17 }, { ptr, i64 } { ptr @str.746, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 17 }, { ptr, i64 } { ptr @str.751, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5537,24 +5555,24 @@ while.body.161: ; preds = %while.hdr.160 while.exit.162: ; preds = %while.hdr.160 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.747, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.752, i64 1 }) ret { ptr, i64 } %callN if.then.163: ; preds = %while.body.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.748, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.753, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.164 if.merge.164: ; preds = %if.then.163, %while.body.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.753, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.758, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.754, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.759, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5583,7 +5601,7 @@ fv.case: ; preds = %if.merge.164 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.164 @@ -5608,7 +5626,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 7 }, { ptr, i64 } { ptr @str.756, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 7 }, { ptr, i64 } { ptr @str.761, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5627,24 +5645,24 @@ while.body.166: ; preds = %while.hdr.165 while.exit.167: ; preds = %while.hdr.165 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.757, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.762, i64 1 }) ret { ptr, i64 } %callN if.then.168: ; preds = %while.body.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.758, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.763, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.169 if.merge.169: ; preds = %if.then.168, %while.body.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.761, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.766, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.762, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.767, 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 @@ -5671,7 +5689,7 @@ fv.case: ; preds = %if.merge.169 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.169 @@ -5686,7 +5704,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 4 }, { ptr, i64 } { ptr @str.764, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 4 }, { ptr, i64 } { ptr @str.769, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5705,24 +5723,24 @@ while.body.171: ; preds = %while.hdr.170 while.exit.172: ; preds = %while.hdr.170 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.765, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.770, i64 1 }) ret { ptr, i64 } %callN if.then.173: ; preds = %while.body.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.766, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.771, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.174 if.merge.174: ; preds = %if.then.173, %while.body.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.768, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.773, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.769, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.774, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -5759,7 +5777,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 10 }, { ptr, i64 } { ptr @str.771, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 10 }, { ptr, i64 } { ptr @str.776, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5778,24 +5796,24 @@ while.body.176: ; preds = %while.hdr.175 while.exit.177: ; preds = %while.hdr.175 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.772, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.777, i64 1 }) ret { ptr, i64 } %callN if.then.178: ; preds = %while.body.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.773, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.778, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.179 if.merge.179: ; preds = %if.then.178, %while.body.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.779, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.784, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.780, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.785, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5861,7 +5879,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 13 }, { ptr, i64 } { ptr @str.782, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 13 }, { ptr, i64 } { ptr @str.787, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5880,24 +5898,24 @@ while.body.181: ; preds = %while.hdr.180 while.exit.182: ; preds = %while.hdr.180 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.783, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.788, i64 1 }) ret { ptr, i64 } %callN if.then.183: ; preds = %while.body.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.784, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.789, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.184 if.merge.184: ; preds = %if.then.183, %while.body.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.787, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.792, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.788, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.793, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5939,7 +5957,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 8 }, { ptr, i64 } { ptr @str.790, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 8 }, { ptr, i64 } { ptr @str.795, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5958,24 +5976,24 @@ while.body.186: ; preds = %while.hdr.185 while.exit.187: ; preds = %while.hdr.185 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.791, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.796, i64 1 }) ret { ptr, i64 } %callN if.then.188: ; preds = %while.body.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.792, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.797, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.189 if.merge.189: ; preds = %if.then.188, %while.body.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.798, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.803, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.799, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.804, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -6036,7 +6054,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 5 }, { ptr, i64 } { ptr @str.801, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 5 }, { ptr, i64 } { ptr @str.806, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6055,24 +6073,24 @@ while.body.191: ; preds = %while.hdr.190 while.exit.192: ; preds = %while.hdr.190 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.802, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.807, i64 1 }) ret { ptr, i64 } %callN if.then.193: ; preds = %while.body.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.803, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.808, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.194 if.merge.194: ; preds = %if.then.193, %while.body.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.807, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.812, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.808, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.813, 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 @@ -6118,7 +6136,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 6 }, { ptr, i64 } { ptr @str.810, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.814, i64 6 }, { ptr, i64 } { ptr @str.815, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6137,24 +6155,24 @@ while.body.196: ; preds = %while.hdr.195 while.exit.197: ; preds = %while.hdr.195 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.811, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.816, i64 1 }) ret { ptr, i64 } %callN if.then.198: ; preds = %while.body.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.812, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.817, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.199 if.merge.199: ; preds = %if.then.198, %while.body.196 %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.816, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.821, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.817, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.822, 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 @@ -6202,7 +6220,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.818, i64 6 }, { ptr, i64 } { ptr @str.819, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.823, i64 6 }, { ptr, i64 } { ptr @str.824, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6221,24 +6239,24 @@ while.body.201: ; preds = %while.hdr.200 while.exit.202: ; preds = %while.hdr.200 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.820, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.825, i64 1 }) ret { ptr, i64 } %callN if.then.203: ; preds = %while.body.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.821, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.826, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.204 if.merge.204: ; preds = %if.then.203, %while.body.201 %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.824, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.829, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.825, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.830, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -6282,7 +6300,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.826, i64 4 }, { ptr, i64 } { ptr @str.827, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.831, i64 4 }, { ptr, i64 } { ptr @str.832, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6301,24 +6319,24 @@ while.body.206: ; preds = %while.hdr.205 while.exit.207: ; preds = %while.hdr.205 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.828, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.833, i64 1 }) ret { ptr, i64 } %callN if.then.208: ; preds = %while.body.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.829, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.834, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.209 if.merge.209: ; preds = %if.then.208, %while.body.206 %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.833, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.838, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.834, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.839, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -6368,7 +6386,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.835, i64 6 }, { ptr, i64 } { ptr @str.836, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.840, i64 6 }, { ptr, i64 } { ptr @str.841, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6387,24 +6405,24 @@ while.body.211: ; preds = %while.hdr.210 while.exit.212: ; preds = %while.hdr.210 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.837, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.842, i64 1 }) ret { ptr, i64 } %callN if.then.213: ; preds = %while.body.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.838, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.843, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.214 if.merge.214: ; preds = %if.then.213, %while.body.211 %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.842, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.847, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.843, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.848, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -6444,7 +6462,7 @@ fv.case20: ; preds = %if.merge.214 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -6453,7 +6471,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.844, i64 12 }, { ptr, i64 } { ptr @str.845, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.849, i64 12 }, { ptr, i64 } { ptr @str.850, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6472,24 +6490,24 @@ while.body.216: ; preds = %while.hdr.215 while.exit.217: ; preds = %while.hdr.215 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.846, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.851, i64 1 }) ret { ptr, i64 } %callN if.then.218: ; preds = %while.body.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.847, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.852, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.219 if.merge.219: ; preds = %if.then.218, %while.body.216 %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.848, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.853, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.849, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.854, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6509,7 +6527,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.850, i64 8 }, { ptr, i64 } { ptr @str.851, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.855, i64 8 }, { ptr, i64 } { ptr @str.856, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6528,24 +6546,24 @@ while.body.221: ; preds = %while.hdr.220 while.exit.222: ; preds = %while.hdr.220 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.852, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.857, i64 1 }) ret { ptr, i64 } %callN if.then.223: ; preds = %while.body.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.853, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.858, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.224 if.merge.224: ; preds = %if.then.223, %while.body.221 %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.857, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.862, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.858, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.863, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -6597,7 +6615,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.859, i64 7 }, { ptr, i64 } { ptr @str.860, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.864, i64 7 }, { ptr, i64 } { ptr @str.865, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6616,24 +6634,24 @@ while.body.226: ; preds = %while.hdr.225 while.exit.227: ; preds = %while.hdr.225 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.861, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.866, i64 1 }) ret { ptr, i64 } %callN if.then.228: ; preds = %while.body.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.862, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.867, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.229 if.merge.229: ; preds = %if.then.228, %while.body.226 %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.866, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.871, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.867, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.872, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6685,7 +6703,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.868, i64 9 }, { ptr, i64 } { ptr @str.869, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.873, i64 9 }, { ptr, i64 } { ptr @str.874, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6704,24 +6722,24 @@ while.body.231: ; preds = %while.hdr.230 while.exit.232: ; preds = %while.hdr.230 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.870, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 1 }) ret { ptr, i64 } %callN if.then.233: ; preds = %while.body.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.871, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.876, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.234 if.merge.234: ; preds = %if.then.233, %while.body.231 %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.874, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.879, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.880, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6764,7 +6782,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.876, i64 4 }, { ptr, i64 } { ptr @str.877, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.881, i64 4 }, { ptr, i64 } { ptr @str.882, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6783,24 +6801,24 @@ while.body.236: ; preds = %while.hdr.235 while.exit.237: ; preds = %while.hdr.235 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.878, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.883, i64 1 }) ret { ptr, i64 } %callN if.then.238: ; preds = %while.body.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.879, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.884, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.239 if.merge.239: ; preds = %if.then.238, %while.body.236 %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.882, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.887, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.883, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.888, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6846,7 +6864,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.884, i64 6 }, { ptr, i64 } { ptr @str.885, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.889, i64 6 }, { ptr, i64 } { ptr @str.890, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6865,24 +6883,24 @@ while.body.241: ; preds = %while.hdr.240 while.exit.242: ; preds = %while.hdr.240 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.886, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.891, i64 1 }) ret { ptr, i64 } %callN if.then.243: ; preds = %while.body.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.887, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.892, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.244 if.merge.244: ; preds = %if.then.243, %while.body.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.895, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.900, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.896, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.901, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -6964,7 +6982,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.897, i64 6 }, { ptr, i64 } { ptr @str.898, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.902, i64 6 }, { ptr, i64 } { ptr @str.903, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6983,24 +7001,24 @@ while.body.246: ; preds = %while.hdr.245 while.exit.247: ; preds = %while.hdr.245 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.899, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.904, i64 1 }) ret { ptr, i64 } %callN if.then.248: ; preds = %while.body.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.900, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.905, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.249 if.merge.249: ; preds = %if.then.248, %while.body.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.905, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.910, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.906, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.911, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -7056,7 +7074,7 @@ entry: %alloca = alloca { [16 x float] }, align 8 %ba.tmp = alloca [16 x float], align 4 store { [16 x float] } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.907, i64 4 }, { ptr, i64 } { ptr @str.908, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.912, i64 4 }, { ptr, i64 } { ptr @str.913, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7075,24 +7093,24 @@ while.body.251: ; preds = %while.hdr.250 while.exit.252: ; preds = %while.hdr.250 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.909, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.914, i64 1 }) ret { ptr, i64 } %callN if.then.253: ; preds = %while.body.251 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.910, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.915, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 if.merge.254: ; preds = %if.then.253, %while.body.251 %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.912, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.917, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.913, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -7127,7 +7145,7 @@ define internal { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %1 entry: %alloca = alloca { float, float }, align 8 store { float, float } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.914, i64 4 }, { ptr, i64 } { ptr @str.915, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.919, i64 4 }, { ptr, i64 } { ptr @str.920, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7146,24 +7164,24 @@ while.body.256: ; preds = %while.hdr.255 while.exit.257: ; preds = %while.hdr.255 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.916, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.921, i64 1 }) ret { ptr, i64 } %callN if.then.258: ; preds = %while.body.256 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.917, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.922, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.259 if.merge.259: ; preds = %if.then.258, %while.body.256 %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.920, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.925, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.921, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.926, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7206,7 +7224,7 @@ define internal { ptr, i64 } @struct_to_string__Point(ptr %0, { i32, i32 } %1) # entry: %alloca = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.922, i64 5 }, { ptr, i64 } { ptr @str.923, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.927, i64 5 }, { ptr, i64 } { ptr @str.928, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7225,24 +7243,24 @@ while.body.261: ; preds = %while.hdr.260 while.exit.262: ; preds = %while.hdr.260 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.924, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.929, i64 1 }) ret { ptr, i64 } %callN if.then.263: ; preds = %while.body.261 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.925, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.930, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 if.merge.264: ; preds = %if.then.263, %while.body.261 %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.928, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.933, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.929, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.934, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7283,7 +7301,7 @@ define internal { ptr, i64 } @struct_to_string__Shape.rect(ptr %0, { float, floa entry: %alloca = alloca { float, float }, align 8 store { float, float } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.930, i64 10 }, { ptr, i64 } { ptr @str.931, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.935, i64 10 }, { ptr, i64 } { ptr @str.936, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7302,24 +7320,24 @@ while.body.266: ; preds = %while.hdr.265 while.exit.267: ; preds = %while.hdr.265 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.932, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.937, i64 1 }) ret { ptr, i64 } %callN if.then.268: ; preds = %while.body.266 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.933, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.938, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.269 if.merge.269: ; preds = %if.then.268, %while.body.266 %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.936, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.941, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.937, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.942, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7366,9 +7384,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.943, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.948, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.938, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.943, 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 @@ -7387,8 +7405,8 @@ entry: if.then.278: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.945, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.944, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.950, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.949, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.279 @@ -7407,9 +7425,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.950, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.955, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.946, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.951, 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 @@ -7428,8 +7446,8 @@ entry: if.then.280: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.952, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.951, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.957, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.956, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 @@ -7459,9 +7477,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.960, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.965, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.953, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.958, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -7478,8 +7496,8 @@ entry: if.then.282: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.962, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.961, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.967, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.966, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.283 @@ -7557,9 +7575,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.971, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.976, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.963, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.968, 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 @@ -7578,8 +7596,8 @@ entry: if.then.284: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.973, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.972, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.978, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.977, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -7598,9 +7616,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.980, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.985, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.974, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.979, 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 @@ -7619,8 +7637,8 @@ entry: if.then.286: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.982, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.981, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.987, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.986, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.287 @@ -7645,9 +7663,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.987, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.992, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.983, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.988, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [8 x i8] }, ptr %alloca, align 8 @@ -7661,8 +7679,8 @@ entry: if.then.288: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.989, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.988, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.994, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.993, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.289 @@ -7714,7 +7732,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.990, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.995, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.300 @@ -7731,12 +7749,12 @@ while.body.301: ; preds = %while.hdr.300 while.exit.302: ; preds = %while.hdr.300 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.991, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.996, i64 1 }) ret { ptr, i64 } %call if.then.303: ; preds = %while.body.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.992, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.997, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.304 @@ -7765,7 +7783,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.993, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.998, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.305 @@ -7782,12 +7800,12 @@ while.body.306: ; preds = %while.hdr.305 while.exit.307: ; preds = %while.hdr.305 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.994, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.999, i64 1 }) ret { ptr, i64 } %call if.then.308: ; preds = %while.body.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1000, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.309 @@ -7817,7 +7835,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.996, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1001, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.310 @@ -7834,12 +7852,12 @@ while.body.311: ; preds = %while.hdr.310 while.exit.312: ; preds = %while.hdr.310 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.997, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1002, i64 1 }) ret { ptr, i64 } %call if.then.313: ; preds = %while.body.311 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.998, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1003, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.314 @@ -7867,7 +7885,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.999, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1004, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.315 @@ -7884,12 +7902,12 @@ while.body.316: ; preds = %while.hdr.315 while.exit.317: ; preds = %while.hdr.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1000, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1005, i64 1 }) ret { ptr, i64 } %call if.then.318: ; preds = %while.body.316 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1001, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1006, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.319 @@ -7918,7 +7936,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1002, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1007, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7935,12 +7953,12 @@ while.body.321: ; preds = %while.hdr.320 while.exit.322: ; preds = %while.hdr.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1003, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1008, i64 1 }) ret { ptr, i64 } %call if.then.323: ; preds = %while.body.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1004, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1009, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7968,7 +7986,7 @@ entry: %ig.tmp = alloca [16 x float], align 4 store [16 x float] %1, ptr %alloca, align 4 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1005, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1010, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.325 @@ -7985,12 +8003,12 @@ while.body.326: ; preds = %while.hdr.325 while.exit.327: ; preds = %while.hdr.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1006, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1011, i64 1 }) ret { ptr, i64 } %call if.then.328: ; preds = %while.body.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1007, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1012, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.329 @@ -8021,7 +8039,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [2 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1008, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1013, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.330 @@ -8038,12 +8056,12 @@ while.body.331: ; preds = %while.hdr.330 while.exit.332: ; preds = %while.hdr.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1009, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1014, i64 1 }) ret { ptr, i64 } %call if.then.333: ; preds = %while.body.331 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1010, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1015, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.334 @@ -8074,7 +8092,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1011, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1016, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.335 @@ -8091,12 +8109,12 @@ while.body.336: ; preds = %while.hdr.335 while.exit.337: ; preds = %while.hdr.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1012, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1017, i64 1 }) ret { ptr, i64 } %call if.then.338: ; preds = %while.body.336 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1013, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1018, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.339 @@ -8126,7 +8144,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1014, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1019, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -8145,12 +8163,12 @@ while.body.348: ; preds = %while.hdr.347 while.exit.349: ; preds = %while.hdr.347 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1015, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1020, i64 1 }) ret { ptr, i64 } %call if.then.350: ; preds = %while.body.348 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1016, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1021, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.351 @@ -8179,7 +8197,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1017, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1022, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8198,12 +8216,12 @@ while.body.353: ; preds = %while.hdr.352 while.exit.354: ; preds = %while.hdr.352 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1018, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1023, i64 1 }) ret { ptr, i64 } %call if.then.355: ; preds = %while.body.353 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1019, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1024, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.356 @@ -8232,7 +8250,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1020, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1025, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.357 @@ -8251,12 +8269,12 @@ while.body.358: ; preds = %while.hdr.357 while.exit.359: ; preds = %while.hdr.357 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1021, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1026, i64 1 }) ret { ptr, i64 } %call if.then.360: ; preds = %while.body.358 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1022, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1027, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.361 @@ -8286,7 +8304,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1023, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1028, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.362 @@ -8305,12 +8323,12 @@ while.body.363: ; preds = %while.hdr.362 while.exit.364: ; preds = %while.hdr.362 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1024, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1029, i64 1 }) ret { ptr, i64 } %call if.then.365: ; preds = %while.body.363 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1025, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1030, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.366 @@ -8340,7 +8358,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1026, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1031, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.367 @@ -8359,12 +8377,12 @@ while.body.368: ; preds = %while.hdr.367 while.exit.369: ; preds = %while.hdr.367 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1027, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1032, i64 1 }) ret { ptr, i64 } %call if.then.370: ; preds = %while.body.368 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1028, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1033, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.371 @@ -8406,12 +8424,12 @@ if.then.407: ; preds = %entry if.else.408: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1031, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1030, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1036, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1035, i64 5 }, { ptr, i64 } %callN) br label %if.merge.409 if.merge.409: ; preds = %if.else.408, %if.then.407 - %bp = phi { ptr, i64 } [ { ptr @str.1029, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] + %bp = phi { ptr, i64 } [ { ptr @str.1034, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] ret { ptr, i64 } %bp } @@ -8434,12 +8452,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1034, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1033, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1039, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1038, i64 11 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.1032, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.1037, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -8462,12 +8480,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1037, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1036, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1042, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1041, i64 4 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.1035, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.1040, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -8490,12 +8508,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1040, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1039, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1045, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1044, i64 11 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.1038, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.1043, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -8518,12 +8536,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1043, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1042, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1048, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1047, i64 6 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.1041, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.1046, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -8545,12 +8563,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1046, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1045, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1051, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1050, i64 5 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.1044, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.1049, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -8573,12 +8591,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1049, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1048, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1054, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1053, i64 9 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.1047, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.1052, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -8601,12 +8619,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1052, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1051, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1057, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1056, i64 18 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.1050, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.1055, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -8629,12 +8647,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1055, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1054, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1060, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1059, i64 5 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.1053, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.1058, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -8657,12 +8675,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1058, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1057, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1063, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1062, i64 3 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.1056, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.1061, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -8685,12 +8703,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1061, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1060, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1066, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1065, i64 4 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.1059, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.1064, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -8713,12 +8731,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1064, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1063, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1069, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1068, i64 9 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.1062, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.1067, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -8741,12 +8759,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1067, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1066, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1072, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1071, i64 4 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.1065, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.1070, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -8768,12 +8786,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1070, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1069, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1075, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1074, i64 8 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.1068, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.1073, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -8796,12 +8814,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1073, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1072, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1078, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1077, i64 6 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.1071, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.1076, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -8823,12 +8841,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1076, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1075, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1081, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1080, i64 9 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.1074, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.1079, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -8851,12 +8869,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1079, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1078, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1084, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1083, i64 7 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.1077, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.1082, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -8879,12 +8897,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1082, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1081, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1087, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1086, i64 5 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.1080, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.1085, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -8907,12 +8925,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1085, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1084, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1090, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1089, i64 7 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.1083, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.1088, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -8935,12 +8953,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1088, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1087, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1093, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1092, i64 4 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.1086, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.1091, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -8963,12 +8981,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1091, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1090, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1096, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1095, i64 7 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.1089, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.1094, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -8991,12 +9009,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1094, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1093, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1099, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1098, i64 5 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.1092, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.1097, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -9019,12 +9037,12 @@ if.then.486: ; preds = %entry if.else.487: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1097, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1096, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1102, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1101, i64 7 }, { ptr, i64 } %callN) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.1095, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.1100, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -9047,12 +9065,12 @@ if.then.489: ; preds = %entry if.else.490: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1100, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1099, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1105, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1104, i64 12 }, { ptr, i64 } %callN) br label %if.merge.491 if.merge.491: ; preds = %if.else.490, %if.then.489 - %bp = phi { ptr, i64 } [ { ptr @str.1098, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.1103, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -9075,12 +9093,12 @@ if.then.492: ; preds = %entry if.else.493: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1103, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1102, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1108, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1107, i64 6 }, { ptr, i64 } %callN) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.1101, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.1106, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -9103,12 +9121,12 @@ if.then.495: ; preds = %entry if.else.496: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1106, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1105, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1111, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1110, i64 7 }, { ptr, i64 } %callN) br label %if.merge.497 if.merge.497: ; preds = %if.else.496, %if.then.495 - %bp = phi { ptr, i64 } [ { ptr @str.1104, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.1109, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -9131,12 +9149,12 @@ if.then.498: ; preds = %entry if.else.499: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1109, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1108, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1114, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1113, i64 4 }, { ptr, i64 } %callN) br label %if.merge.500 if.merge.500: ; preds = %if.else.499, %if.then.498 - %bp = phi { ptr, i64 } [ { ptr @str.1107, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.1112, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -9159,12 +9177,12 @@ if.then.501: ; preds = %entry if.else.502: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1112, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1111, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1117, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1116, i64 6 }, { ptr, i64 } %callN) br label %if.merge.503 if.merge.503: ; preds = %if.else.502, %if.then.501 - %bp = phi { ptr, i64 } [ { ptr @str.1110, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.1115, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -9187,12 +9205,12 @@ if.then.504: ; preds = %entry if.else.505: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1115, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1114, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1120, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1119, i64 5 }, { ptr, i64 } %callN) br label %if.merge.506 if.merge.506: ; preds = %if.else.505, %if.then.504 - %bp = phi { ptr, i64 } [ { ptr @str.1113, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.1118, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -9215,12 +9233,12 @@ if.then.507: ; preds = %entry if.else.508: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1118, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1117, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1123, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1122, i64 6 }, { ptr, i64 } %callN) br label %if.merge.509 if.merge.509: ; preds = %if.else.508, %if.then.507 - %bp = phi { ptr, i64 } [ { ptr @str.1116, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.1121, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -9243,12 +9261,12 @@ if.then.510: ; preds = %entry if.else.511: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1121, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1120, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1126, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1125, i64 7 }, { ptr, i64 } %callN) br label %if.merge.512 if.merge.512: ; preds = %if.else.511, %if.then.510 - %bp = phi { ptr, i64 } [ { ptr @str.1119, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.1124, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -9271,12 +9289,12 @@ if.then.513: ; preds = %entry if.else.514: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1124, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1123, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1129, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1128, i64 6 }, { ptr, i64 } %callN) br label %if.merge.515 if.merge.515: ; preds = %if.else.514, %if.then.513 - %bp = phi { ptr, i64 } [ { ptr @str.1122, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.1127, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -9299,12 +9317,12 @@ if.then.516: ; preds = %entry if.else.517: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1127, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1126, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1132, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1131, i64 7 }, { ptr, i64 } %callN) br label %if.merge.518 if.merge.518: ; preds = %if.else.517, %if.then.516 - %bp = phi { ptr, i64 } [ { ptr @str.1125, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] + %bp = phi { ptr, i64 } [ { ptr @str.1130, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] ret { ptr, i64 } %bp } @@ -9320,7 +9338,7 @@ entry: br i1 %lnot, label %if.then.525, label %if.merge.526 if.then.525: ; preds = %entry - ret { ptr, i64 } { ptr @str.1128, i64 4 } + ret { ptr, i64 } { ptr @str.1133, i64 4 } if.merge.526: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -9344,7 +9362,7 @@ entry: br i1 %lnot, label %if.then.527, label %if.merge.528 if.then.527: ; preds = %entry - ret { ptr, i64 } { ptr @str.1129, i64 4 } + ret { ptr, i64 } { ptr @str.1134, i64 4 } if.merge.528: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -9368,7 +9386,7 @@ entry: br i1 %lnot, label %if.then.529, label %if.merge.530 if.then.529: ; preds = %entry - ret { ptr, i64 } { ptr @str.1130, i64 4 } + ret { ptr, i64 } { ptr @str.1135, i64 4 } if.merge.530: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9392,7 +9410,7 @@ entry: br i1 %lnot, label %if.then.531, label %if.merge.532 if.then.531: ; preds = %entry - ret { ptr, i64 } { ptr @str.1131, i64 4 } + ret { ptr, i64 } { ptr @str.1136, i64 4 } if.merge.532: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0032-basic-ufcs-return-type.ir b/examples/expected/0032-basic-ufcs-return-type.ir index 21e12aa..ba4787d 100644 --- a/examples/expected/0032-basic-ufcs-return-type.ir +++ b/examples/expected/0032-basic-ufcs-return-type.ir @@ -1,648 +1,648 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.466 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.467 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.469 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.470 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.471 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.472 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.474 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.475 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [168 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.471 = private constant [9 x i8] c"Overflow\00" -@tag.str.472 = private constant [3 x i8] c"Io\00" -@tag.str.473 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.474 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.475 = private constant [10 x i8] c"BadEscape\00" -@tag.str.476 = private constant [10 x i8] c"BadNumber\00" -@tag.str.477 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.478 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.479 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.480 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.481 = private constant [13 x i8] c"MissingValue\00" -@tag.str.482 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.483 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.471, i64 8 }, { ptr, i64 } { ptr @tag.str.472, i64 2 }, { ptr, i64 } { ptr @tag.str.473, i64 15 }, { ptr, i64 } { ptr @tag.str.474, i64 13 }, { ptr, i64 } { ptr @tag.str.475, i64 9 }, { ptr, i64 } { ptr @tag.str.476, i64 9 }, { ptr, i64 } { ptr @tag.str.477, i64 15 }, { ptr, i64 } { ptr @tag.str.478, i64 14 }, { ptr, i64 } { ptr @tag.str.479, i64 14 }, { ptr, i64 } { ptr @tag.str.480, i64 11 }, { ptr, i64 } { ptr @tag.str.481, i64 12 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 12 }] +@tag.str.476 = private constant [9 x i8] c"Overflow\00" +@tag.str.477 = private constant [3 x i8] c"Io\00" +@tag.str.478 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.479 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.480 = private constant [10 x i8] c"BadEscape\00" +@tag.str.481 = private constant [10 x i8] c"BadNumber\00" +@tag.str.482 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.483 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.484 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.485 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.486 = private constant [13 x i8] c"MissingValue\00" +@tag.str.487 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.488 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.476, i64 8 }, { ptr, i64 } { ptr @tag.str.477, i64 2 }, { ptr, i64 } { ptr @tag.str.478, i64 15 }, { ptr, i64 } { ptr @tag.str.479, i64 13 }, { ptr, i64 } { ptr @tag.str.480, i64 9 }, { ptr, i64 } { ptr @tag.str.481, i64 9 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 14 }, { ptr, i64 } { ptr @tag.str.484, i64 14 }, { ptr, i64 } { ptr @tag.str.485, i64 11 }, { ptr, i64 } { ptr @tag.str.486, i64 12 }, { ptr, i64 } { ptr @tag.str.487, i64 15 }, { ptr, i64 } { ptr @tag.str.488, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.484 = private constant [5 x i8] c"bool\00" -@tn.str.485 = private constant [3 x i8] c"s8\00" -@tn.str.486 = private constant [4 x i8] c"s16\00" -@tn.str.487 = private constant [4 x i8] c"s32\00" -@tn.str.488 = private constant [4 x i8] c"s64\00" -@tn.str.489 = private constant [3 x i8] c"u8\00" -@tn.str.490 = private constant [4 x i8] c"u16\00" -@tn.str.491 = private constant [4 x i8] c"u32\00" -@tn.str.492 = private constant [4 x i8] c"u64\00" -@tn.str.493 = private constant [4 x i8] c"f32\00" -@tn.str.494 = private constant [4 x i8] c"f64\00" -@tn.str.495 = private constant [7 x i8] c"string\00" -@tn.str.496 = private constant [4 x i8] c"Any\00" -@tn.str.497 = private constant [9 x i8] c"noreturn\00" -@tn.str.498 = private constant [6 x i8] c"isize\00" -@tn.str.499 = private constant [6 x i8] c"usize\00" -@tn.str.500 = private constant [5 x i8] c"void\00" -@tn.str.501 = private constant [6 x i8] c"*void\00" -@tn.str.502 = private constant [16 x i8] c"Source_Location\00" -@tn.str.503 = private constant [11 x i8] c"CAllocator\00" -@tn.str.504 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.505 = private constant [4 x i8] c"GPA\00" -@tn.str.506 = private constant [5 x i8] c"*GPA\00" -@tn.str.507 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.508 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.509 = private constant [10 x i8] c"Allocator\00" -@tn.str.510 = private constant [6 x i8] c"Arena\00" -@tn.str.511 = private constant [7 x i8] c"*Arena\00" -@tn.str.512 = private constant [6 x i8] c"[*]u8\00" -@tn.str.513 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.514 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.515 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.516 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.517 = private constant [8 x i8] c"Context\00" -@tn.str.518 = private constant [7 x i8] c"[4]s64\00" -@tn.str.519 = private constant [9 x i8] c"[]string\00" -@tn.str.520 = private constant [9 x i8] c"OpenMode\00" -@tn.str.521 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.522 = private constant [5 x i8] c"File\00" -@tn.str.523 = private constant [6 x i8] c"*File\00" -@tn.str.524 = private constant [6 x i8] c"?File\00" -@tn.str.525 = private constant [8 x i8] c"?string\00" -@tn.str.526 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.527 = private constant [4 x i8] c"*u8\00" -@tn.str.528 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.529 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.530 = private constant [5 x i8] c"*s32\00" -@tn.str.531 = private constant [9 x i8] c"SockAddr\00" -@tn.str.532 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.533 = private constant [5 x i8] c"*u32\00" -@tn.str.534 = private constant [10 x i8] c"JsonError\00" -@tn.str.535 = private constant [6 x i8] c"Array\00" -@tn.str.536 = private constant [7 x i8] c"Object\00" -@tn.str.537 = private constant [6 x i8] c"Value\00" -@tn.str.538 = private constant [7 x i8] c"Member\00" -@tn.str.539 = private constant [9 x i8] c"[*]Value\00" -@tn.str.540 = private constant [7 x i8] c"*Array\00" -@tn.str.541 = private constant [10 x i8] c"[*]Member\00" -@tn.str.542 = private constant [8 x i8] c"*Object\00" -@tn.str.543 = private constant [5 x i8] c"[]u8\00" -@tn.str.544 = private constant [5 x i8] c"Sink\00" -@tn.str.545 = private constant [6 x i8] c"*Sink\00" -@tn.str.546 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.547 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.548 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.549 = private constant [7 x i8] c"Parser\00" -@tn.str.550 = private constant [8 x i8] c"*Parser\00" -@tn.str.551 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.552 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.553 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.554 = private constant [13 x i8] c"Architecture\00" -@tn.str.555 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.556 = private constant [11 x i8] c"() -> bool\00" -@tn.str.557 = private constant [5 x i8] c"*s64\00" -@tn.str.558 = private constant [9 x i8] c"CliError\00" -@tn.str.559 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.560 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.561 = private constant [8 x i8] c"Command\00" -@tn.str.562 = private constant [10 x i8] c"FlagValue\00" -@tn.str.563 = private constant [5 x i8] c"Diag\00" -@tn.str.564 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.565 = private constant [7 x i8] c"Parsed\00" -@tn.str.566 = private constant [8 x i8] c"*Parsed\00" -@tn.str.567 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.568 = private constant [10 x i8] c"[]Command\00" -@tn.str.569 = private constant [6 x i8] c"*Diag\00" -@tn.str.570 = private constant [7 x i8] c"[8]s64\00" -@tn.str.571 = private constant [7 x i8] c"[64]u8\00" -@tn.str.572 = private constant [7 x i8] c"Sha256\00" -@tn.str.573 = private constant [8 x i8] c"*Sha256\00" -@tn.str.574 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.575 = private constant [8 x i8] c"[64]s64\00" -@tn.str.576 = private constant [8 x i8] c"[16]f32\00" -@tn.str.577 = private constant [5 x i8] c"Mat4\00" -@tn.str.578 = private constant [5 x i8] c"Vec2\00" -@tn.str.579 = private constant [6 x i8] c"Point\00" -@tn.str.580 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.581 = private constant [7 x i8] c"**void\00" -@tn.str.582 = private constant [8 x i8] c"*string\00" -@tn.str.583 = private constant [6 x i8] c"[]Any\00" -@tn.str.584 = private constant [5 x i8] c"*Any\00" -@tn.str.585 = private constant [7 x i8] c"*[]Any\00" -@tn.str.586 = private constant [6 x i8] c"*bool\00" -@tn.str.587 = private constant [7 x i8] c"*Point\00" -@tn.str.588 = private constant [7 x i8] c"[1]Any\00" -@tn.str.589 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.590 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.591 = private constant [5 x i8] c"*f64\00" -@tn.str.592 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.593 = private constant [11 x i8] c"*Allocator\00" -@tn.str.594 = private constant [9 x i8] c"*Context\00" -@tn.str.595 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.596 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.597 = private constant [8 x i8] c"*Member\00" -@tn.str.598 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.599 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.600 = private constant [9 x i8] c"*Command\00" -@tn.str.601 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.602 = private constant [6 x i8] c"*Mat4\00" -@tn.str.603 = private constant [6 x i8] c"*Vec2\00" -@tn.str.604 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.605 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.606 = private constant [7 x i8] c"*Value\00" -@tn.str.607 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.608 = private constant [14 x i8] c"*Architecture\00" -@tn.str.609 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.610 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.611 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.612 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.613 = private constant [9 x i8] c"*[16]f32\00" -@tn.str.614 = private constant [10 x i8] c"*[]string\00" -@tn.str.615 = private constant [6 x i8] c"*[]u8\00" -@tn.str.616 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.617 = private constant [11 x i8] c"*[]Command\00" -@tn.str.618 = private constant [6 x i8] c"**GPA\00" -@tn.str.619 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.620 = private constant [8 x i8] c"**Arena\00" -@tn.str.621 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.622 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.623 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.624 = private constant [7 x i8] c"**File\00" -@tn.str.625 = private constant [5 x i8] c"**u8\00" -@tn.str.626 = private constant [6 x i8] c"**s32\00" -@tn.str.627 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.628 = private constant [6 x i8] c"**u32\00" -@tn.str.629 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.630 = private constant [8 x i8] c"**Array\00" -@tn.str.631 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.632 = private constant [9 x i8] c"**Object\00" -@tn.str.633 = private constant [7 x i8] c"**Sink\00" -@tn.str.634 = private constant [9 x i8] c"**Parser\00" -@tn.str.635 = private constant [6 x i8] c"**s64\00" -@tn.str.636 = private constant [9 x i8] c"**Parsed\00" -@tn.str.637 = private constant [7 x i8] c"**Diag\00" -@tn.str.638 = private constant [9 x i8] c"**Sha256\00" -@tn.str.639 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.640 = private constant [8 x i8] c"***void\00" -@tn.str.641 = private constant [9 x i8] c"**string\00" -@tn.str.642 = private constant [6 x i8] c"**Any\00" -@tn.str.643 = private constant [8 x i8] c"**[]Any\00" -@tn.str.644 = private constant [7 x i8] c"**bool\00" -@tn.str.645 = private constant [8 x i8] c"**Point\00" -@tn.str.646 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.647 = private constant [7 x i8] c"*?File\00" -@tn.str.648 = private constant [9 x i8] c"*?string\00" -@tn.str.649 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.650 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [168 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.484, i64 4 }, { ptr, i64 } { ptr @tn.str.485, i64 2 }, { ptr, i64 } { ptr @tn.str.486, i64 3 }, { ptr, i64 } { ptr @tn.str.487, i64 3 }, { ptr, i64 } { ptr @tn.str.488, i64 3 }, { ptr, i64 } { ptr @tn.str.489, i64 2 }, { ptr, i64 } { ptr @tn.str.490, i64 3 }, { ptr, i64 } { ptr @tn.str.491, i64 3 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 3 }, { ptr, i64 } { ptr @tn.str.495, i64 6 }, { ptr, i64 } { ptr @tn.str.496, i64 3 }, { ptr, i64 } { ptr @tn.str.497, i64 8 }, { ptr, i64 } { ptr @tn.str.498, i64 5 }, { ptr, i64 } { ptr @tn.str.499, i64 5 }, { ptr, i64 } { ptr @tn.str.500, i64 4 }, { ptr, i64 } { ptr @tn.str.501, i64 5 }, { ptr, i64 } { ptr @tn.str.502, i64 15 }, { ptr, i64 } { ptr @tn.str.503, i64 10 }, { ptr, i64 } { ptr @tn.str.504, i64 11 }, { ptr, i64 } { ptr @tn.str.505, i64 3 }, { ptr, i64 } { ptr @tn.str.506, i64 4 }, { ptr, i64 } { ptr @tn.str.507, i64 10 }, { ptr, i64 } { ptr @tn.str.508, i64 11 }, { ptr, i64 } { ptr @tn.str.509, i64 9 }, { ptr, i64 } { ptr @tn.str.510, i64 5 }, { ptr, i64 } { ptr @tn.str.511, i64 6 }, { ptr, i64 } { ptr @tn.str.512, i64 5 }, { ptr, i64 } { ptr @tn.str.513, i64 8 }, { ptr, i64 } { ptr @tn.str.514, i64 9 }, { ptr, i64 } { ptr @tn.str.515, i64 17 }, { ptr, i64 } { ptr @tn.str.516, i64 18 }, { ptr, i64 } { ptr @tn.str.517, i64 7 }, { ptr, i64 } { ptr @tn.str.518, i64 6 }, { ptr, i64 } { ptr @tn.str.519, i64 8 }, { ptr, i64 } { ptr @tn.str.520, i64 8 }, { ptr, i64 } { ptr @tn.str.521, i64 8 }, { ptr, i64 } { ptr @tn.str.522, i64 4 }, { ptr, i64 } { ptr @tn.str.523, i64 5 }, { ptr, i64 } { ptr @tn.str.524, i64 5 }, { ptr, i64 } { ptr @tn.str.525, i64 7 }, { ptr, i64 } { ptr @tn.str.526, i64 10 }, { ptr, i64 } { ptr @tn.str.527, i64 3 }, { ptr, i64 } { ptr @tn.str.528, i64 13 }, { ptr, i64 } { ptr @tn.str.529, i64 14 }, { ptr, i64 } { ptr @tn.str.530, i64 4 }, { ptr, i64 } { ptr @tn.str.531, i64 8 }, { ptr, i64 } { ptr @tn.str.532, i64 9 }, { ptr, i64 } { ptr @tn.str.533, i64 4 }, { ptr, i64 } { ptr @tn.str.534, i64 9 }, { ptr, i64 } { ptr @tn.str.535, i64 5 }, { ptr, i64 } { ptr @tn.str.536, i64 6 }, { ptr, i64 } { ptr @tn.str.537, i64 5 }, { ptr, i64 } { ptr @tn.str.538, i64 6 }, { ptr, i64 } { ptr @tn.str.539, i64 8 }, { ptr, i64 } { ptr @tn.str.540, i64 6 }, { ptr, i64 } { ptr @tn.str.541, i64 9 }, { ptr, i64 } { ptr @tn.str.542, i64 7 }, { ptr, i64 } { ptr @tn.str.543, i64 4 }, { ptr, i64 } { ptr @tn.str.544, i64 4 }, { ptr, i64 } { ptr @tn.str.545, i64 5 }, { ptr, i64 } { ptr @tn.str.546, i64 16 }, { ptr, i64 } { ptr @tn.str.547, i64 14 }, { ptr, i64 } { ptr @tn.str.548, i64 21 }, { ptr, i64 } { ptr @tn.str.549, i64 6 }, { ptr, i64 } { ptr @tn.str.550, i64 7 }, { ptr, i64 } { ptr @tn.str.551, i64 24 }, { ptr, i64 } { ptr @tn.str.552, i64 23 }, { ptr, i64 } { ptr @tn.str.553, i64 15 }, { ptr, i64 } { ptr @tn.str.554, i64 12 }, { ptr, i64 } { ptr @tn.str.555, i64 12 }, { ptr, i64 } { ptr @tn.str.556, i64 10 }, { ptr, i64 } { ptr @tn.str.557, i64 4 }, { ptr, i64 } { ptr @tn.str.558, i64 8 }, { ptr, i64 } { ptr @tn.str.559, i64 8 }, { ptr, i64 } { ptr @tn.str.560, i64 10 }, { ptr, i64 } { ptr @tn.str.561, i64 7 }, { ptr, i64 } { ptr @tn.str.562, i64 9 }, { ptr, i64 } { ptr @tn.str.563, i64 4 }, { ptr, i64 } { ptr @tn.str.564, i64 13 }, { ptr, i64 } { ptr @tn.str.565, i64 6 }, { ptr, i64 } { ptr @tn.str.566, i64 7 }, { ptr, i64 } { ptr @tn.str.567, i64 18 }, { ptr, i64 } { ptr @tn.str.568, i64 9 }, { ptr, i64 } { ptr @tn.str.569, i64 5 }, { ptr, i64 } { ptr @tn.str.570, i64 6 }, { ptr, i64 } { ptr @tn.str.571, i64 6 }, { ptr, i64 } { ptr @tn.str.572, i64 6 }, { ptr, i64 } { ptr @tn.str.573, i64 7 }, { ptr, i64 } { ptr @tn.str.574, i64 7 }, { ptr, i64 } { ptr @tn.str.575, i64 7 }, { ptr, i64 } { ptr @tn.str.576, i64 7 }, { ptr, i64 } { ptr @tn.str.577, i64 4 }, { ptr, i64 } { ptr @tn.str.578, i64 4 }, { ptr, i64 } { ptr @tn.str.579, i64 5 }, { ptr, i64 } { ptr @tn.str.580, i64 12 }, { ptr, i64 } { ptr @tn.str.581, i64 6 }, { ptr, i64 } { ptr @tn.str.582, i64 7 }, { ptr, i64 } { ptr @tn.str.583, i64 5 }, { ptr, i64 } { ptr @tn.str.584, i64 4 }, { ptr, i64 } { ptr @tn.str.585, i64 6 }, { ptr, i64 } { ptr @tn.str.586, i64 5 }, { ptr, i64 } { ptr @tn.str.587, i64 6 }, { ptr, i64 } { ptr @tn.str.588, i64 6 }, { ptr, i64 } { ptr @tn.str.589, i64 7 }, { ptr, i64 } { ptr @tn.str.590, i64 7 }, { ptr, i64 } { ptr @tn.str.591, i64 4 }, { ptr, i64 } { ptr @tn.str.592, i64 16 }, { ptr, i64 } { ptr @tn.str.593, i64 10 }, { ptr, i64 } { ptr @tn.str.594, i64 8 }, { ptr, i64 } { ptr @tn.str.595, i64 11 }, { ptr, i64 } { ptr @tn.str.596, i64 14 }, { ptr, i64 } { ptr @tn.str.597, i64 7 }, { ptr, i64 } { ptr @tn.str.598, i64 13 }, { ptr, i64 } { ptr @tn.str.599, i64 9 }, { ptr, i64 } { ptr @tn.str.600, i64 8 }, { ptr, i64 } { ptr @tn.str.601, i64 10 }, { ptr, i64 } { ptr @tn.str.602, i64 5 }, { ptr, i64 } { ptr @tn.str.603, i64 5 }, { ptr, i64 } { ptr @tn.str.604, i64 9 }, { ptr, i64 } { ptr @tn.str.605, i64 9 }, { ptr, i64 } { ptr @tn.str.606, i64 6 }, { ptr, i64 } { ptr @tn.str.607, i64 16 }, { ptr, i64 } { ptr @tn.str.608, i64 13 }, { ptr, i64 } { ptr @tn.str.609, i64 14 }, { ptr, i64 } { ptr @tn.str.610, i64 7 }, { ptr, i64 } { ptr @tn.str.611, i64 7 }, { ptr, i64 } { ptr @tn.str.612, i64 8 }, { ptr, i64 } { ptr @tn.str.613, i64 8 }, { ptr, i64 } { ptr @tn.str.614, i64 9 }, { ptr, i64 } { ptr @tn.str.615, i64 5 }, { ptr, i64 } { ptr @tn.str.616, i64 11 }, { ptr, i64 } { ptr @tn.str.617, i64 10 }, { ptr, i64 } { ptr @tn.str.618, i64 5 }, { ptr, i64 } { ptr @tn.str.619, i64 12 }, { ptr, i64 } { ptr @tn.str.620, i64 7 }, { ptr, i64 } { ptr @tn.str.621, i64 6 }, { ptr, i64 } { ptr @tn.str.622, i64 10 }, { ptr, i64 } { ptr @tn.str.623, i64 19 }, { ptr, i64 } { ptr @tn.str.624, i64 6 }, { ptr, i64 } { ptr @tn.str.625, i64 4 }, { ptr, i64 } { ptr @tn.str.626, i64 5 }, { ptr, i64 } { ptr @tn.str.627, i64 10 }, { ptr, i64 } { ptr @tn.str.628, i64 5 }, { ptr, i64 } { ptr @tn.str.629, i64 9 }, { ptr, i64 } { ptr @tn.str.630, i64 7 }, { ptr, i64 } { ptr @tn.str.631, i64 10 }, { ptr, i64 } { ptr @tn.str.632, i64 8 }, { ptr, i64 } { ptr @tn.str.633, i64 6 }, { ptr, i64 } { ptr @tn.str.634, i64 8 }, { ptr, i64 } { ptr @tn.str.635, i64 5 }, { ptr, i64 } { ptr @tn.str.636, i64 8 }, { ptr, i64 } { ptr @tn.str.637, i64 6 }, { ptr, i64 } { ptr @tn.str.638, i64 8 }, { ptr, i64 } { ptr @tn.str.639, i64 13 }, { ptr, i64 } { ptr @tn.str.640, i64 7 }, { ptr, i64 } { ptr @tn.str.641, i64 8 }, { ptr, i64 } { ptr @tn.str.642, i64 5 }, { ptr, i64 } { ptr @tn.str.643, i64 7 }, { ptr, i64 } { ptr @tn.str.644, i64 6 }, { ptr, i64 } { ptr @tn.str.645, i64 7 }, { ptr, i64 } { ptr @tn.str.646, i64 8 }, { ptr, i64 } { ptr @tn.str.647, i64 6 }, { ptr, i64 } { ptr @tn.str.648, i64 8 }, { ptr, i64 } { ptr @tn.str.649, i64 15 }, { ptr, i64 } { ptr @tn.str.650, i64 8 }] -@str.651 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.652 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.653 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.654 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.655 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.489 = private constant [5 x i8] c"bool\00" +@tn.str.490 = private constant [3 x i8] c"s8\00" +@tn.str.491 = private constant [4 x i8] c"s16\00" +@tn.str.492 = private constant [4 x i8] c"s32\00" +@tn.str.493 = private constant [4 x i8] c"s64\00" +@tn.str.494 = private constant [3 x i8] c"u8\00" +@tn.str.495 = private constant [4 x i8] c"u16\00" +@tn.str.496 = private constant [4 x i8] c"u32\00" +@tn.str.497 = private constant [4 x i8] c"u64\00" +@tn.str.498 = private constant [4 x i8] c"f32\00" +@tn.str.499 = private constant [4 x i8] c"f64\00" +@tn.str.500 = private constant [7 x i8] c"string\00" +@tn.str.501 = private constant [4 x i8] c"Any\00" +@tn.str.502 = private constant [9 x i8] c"noreturn\00" +@tn.str.503 = private constant [6 x i8] c"isize\00" +@tn.str.504 = private constant [6 x i8] c"usize\00" +@tn.str.505 = private constant [5 x i8] c"void\00" +@tn.str.506 = private constant [6 x i8] c"*void\00" +@tn.str.507 = private constant [16 x i8] c"Source_Location\00" +@tn.str.508 = private constant [10 x i8] c"Allocator\00" +@tn.str.509 = private constant [11 x i8] c"CAllocator\00" +@tn.str.510 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.511 = private constant [4 x i8] c"GPA\00" +@tn.str.512 = private constant [5 x i8] c"*GPA\00" +@tn.str.513 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.514 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.515 = private constant [6 x i8] c"Arena\00" +@tn.str.516 = private constant [7 x i8] c"*Arena\00" +@tn.str.517 = private constant [6 x i8] c"[*]u8\00" +@tn.str.518 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.519 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.520 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.521 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.522 = private constant [8 x i8] c"Context\00" +@tn.str.523 = private constant [7 x i8] c"[4]s64\00" +@tn.str.524 = private constant [9 x i8] c"[]string\00" +@tn.str.525 = private constant [9 x i8] c"OpenMode\00" +@tn.str.526 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.527 = private constant [5 x i8] c"File\00" +@tn.str.528 = private constant [6 x i8] c"*File\00" +@tn.str.529 = private constant [6 x i8] c"?File\00" +@tn.str.530 = private constant [8 x i8] c"?string\00" +@tn.str.531 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.532 = private constant [4 x i8] c"*u8\00" +@tn.str.533 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.534 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.535 = private constant [5 x i8] c"*s32\00" +@tn.str.536 = private constant [9 x i8] c"SockAddr\00" +@tn.str.537 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.538 = private constant [5 x i8] c"*u32\00" +@tn.str.539 = private constant [10 x i8] c"JsonError\00" +@tn.str.540 = private constant [6 x i8] c"Array\00" +@tn.str.541 = private constant [7 x i8] c"Object\00" +@tn.str.542 = private constant [6 x i8] c"Value\00" +@tn.str.543 = private constant [7 x i8] c"Member\00" +@tn.str.544 = private constant [9 x i8] c"[*]Value\00" +@tn.str.545 = private constant [7 x i8] c"*Array\00" +@tn.str.546 = private constant [10 x i8] c"[*]Member\00" +@tn.str.547 = private constant [8 x i8] c"*Object\00" +@tn.str.548 = private constant [5 x i8] c"[]u8\00" +@tn.str.549 = private constant [5 x i8] c"Sink\00" +@tn.str.550 = private constant [6 x i8] c"*Sink\00" +@tn.str.551 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.552 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.553 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.554 = private constant [7 x i8] c"Parser\00" +@tn.str.555 = private constant [8 x i8] c"*Parser\00" +@tn.str.556 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.557 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.558 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.559 = private constant [13 x i8] c"Architecture\00" +@tn.str.560 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.561 = private constant [11 x i8] c"() -> bool\00" +@tn.str.562 = private constant [5 x i8] c"*s64\00" +@tn.str.563 = private constant [9 x i8] c"CliError\00" +@tn.str.564 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.565 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.566 = private constant [8 x i8] c"Command\00" +@tn.str.567 = private constant [10 x i8] c"FlagValue\00" +@tn.str.568 = private constant [5 x i8] c"Diag\00" +@tn.str.569 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.570 = private constant [7 x i8] c"Parsed\00" +@tn.str.571 = private constant [8 x i8] c"*Parsed\00" +@tn.str.572 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.573 = private constant [10 x i8] c"[]Command\00" +@tn.str.574 = private constant [6 x i8] c"*Diag\00" +@tn.str.575 = private constant [7 x i8] c"[8]s64\00" +@tn.str.576 = private constant [7 x i8] c"[64]u8\00" +@tn.str.577 = private constant [7 x i8] c"Sha256\00" +@tn.str.578 = private constant [8 x i8] c"*Sha256\00" +@tn.str.579 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.580 = private constant [8 x i8] c"[64]s64\00" +@tn.str.581 = private constant [8 x i8] c"[16]f32\00" +@tn.str.582 = private constant [5 x i8] c"Mat4\00" +@tn.str.583 = private constant [5 x i8] c"Vec2\00" +@tn.str.584 = private constant [6 x i8] c"Point\00" +@tn.str.585 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.586 = private constant [7 x i8] c"**void\00" +@tn.str.587 = private constant [8 x i8] c"*string\00" +@tn.str.588 = private constant [6 x i8] c"[]Any\00" +@tn.str.589 = private constant [5 x i8] c"*Any\00" +@tn.str.590 = private constant [7 x i8] c"*[]Any\00" +@tn.str.591 = private constant [6 x i8] c"*bool\00" +@tn.str.592 = private constant [7 x i8] c"*Point\00" +@tn.str.593 = private constant [7 x i8] c"[1]Any\00" +@tn.str.594 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.595 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.596 = private constant [5 x i8] c"*f64\00" +@tn.str.597 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.598 = private constant [11 x i8] c"*Allocator\00" +@tn.str.599 = private constant [9 x i8] c"*Context\00" +@tn.str.600 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.601 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.602 = private constant [8 x i8] c"*Member\00" +@tn.str.603 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.604 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.605 = private constant [9 x i8] c"*Command\00" +@tn.str.606 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.607 = private constant [6 x i8] c"*Mat4\00" +@tn.str.608 = private constant [6 x i8] c"*Vec2\00" +@tn.str.609 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.610 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.611 = private constant [7 x i8] c"*Value\00" +@tn.str.612 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.613 = private constant [14 x i8] c"*Architecture\00" +@tn.str.614 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.615 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.616 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.617 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.618 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.619 = private constant [10 x i8] c"*[]string\00" +@tn.str.620 = private constant [6 x i8] c"*[]u8\00" +@tn.str.621 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.622 = private constant [11 x i8] c"*[]Command\00" +@tn.str.623 = private constant [6 x i8] c"**GPA\00" +@tn.str.624 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.625 = private constant [8 x i8] c"**Arena\00" +@tn.str.626 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.627 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.628 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.629 = private constant [7 x i8] c"**File\00" +@tn.str.630 = private constant [5 x i8] c"**u8\00" +@tn.str.631 = private constant [6 x i8] c"**s32\00" +@tn.str.632 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.633 = private constant [6 x i8] c"**u32\00" +@tn.str.634 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.635 = private constant [8 x i8] c"**Array\00" +@tn.str.636 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.637 = private constant [9 x i8] c"**Object\00" +@tn.str.638 = private constant [7 x i8] c"**Sink\00" +@tn.str.639 = private constant [9 x i8] c"**Parser\00" +@tn.str.640 = private constant [6 x i8] c"**s64\00" +@tn.str.641 = private constant [9 x i8] c"**Parsed\00" +@tn.str.642 = private constant [7 x i8] c"**Diag\00" +@tn.str.643 = private constant [9 x i8] c"**Sha256\00" +@tn.str.644 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.645 = private constant [8 x i8] c"***void\00" +@tn.str.646 = private constant [9 x i8] c"**string\00" +@tn.str.647 = private constant [6 x i8] c"**Any\00" +@tn.str.648 = private constant [8 x i8] c"**[]Any\00" +@tn.str.649 = private constant [7 x i8] c"**bool\00" +@tn.str.650 = private constant [8 x i8] c"**Point\00" +@tn.str.651 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.652 = private constant [7 x i8] c"*?File\00" +@tn.str.653 = private constant [9 x i8] c"*?string\00" +@tn.str.654 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.655 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [168 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.489, i64 4 }, { ptr, i64 } { ptr @tn.str.490, i64 2 }, { ptr, i64 } { ptr @tn.str.491, i64 3 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 2 }, { ptr, i64 } { ptr @tn.str.495, i64 3 }, { ptr, i64 } { ptr @tn.str.496, i64 3 }, { ptr, i64 } { ptr @tn.str.497, i64 3 }, { ptr, i64 } { ptr @tn.str.498, i64 3 }, { ptr, i64 } { ptr @tn.str.499, i64 3 }, { ptr, i64 } { ptr @tn.str.500, i64 6 }, { ptr, i64 } { ptr @tn.str.501, i64 3 }, { ptr, i64 } { ptr @tn.str.502, i64 8 }, { ptr, i64 } { ptr @tn.str.503, i64 5 }, { ptr, i64 } { ptr @tn.str.504, i64 5 }, { ptr, i64 } { ptr @tn.str.505, i64 4 }, { ptr, i64 } { ptr @tn.str.506, i64 5 }, { ptr, i64 } { ptr @tn.str.507, i64 15 }, { ptr, i64 } { ptr @tn.str.508, i64 9 }, { ptr, i64 } { ptr @tn.str.509, i64 10 }, { ptr, i64 } { ptr @tn.str.510, i64 11 }, { ptr, i64 } { ptr @tn.str.511, i64 3 }, { ptr, i64 } { ptr @tn.str.512, i64 4 }, { ptr, i64 } { ptr @tn.str.513, i64 10 }, { ptr, i64 } { ptr @tn.str.514, i64 11 }, { ptr, i64 } { ptr @tn.str.515, i64 5 }, { ptr, i64 } { ptr @tn.str.516, i64 6 }, { ptr, i64 } { ptr @tn.str.517, i64 5 }, { ptr, i64 } { ptr @tn.str.518, i64 8 }, { ptr, i64 } { ptr @tn.str.519, i64 9 }, { ptr, i64 } { ptr @tn.str.520, i64 17 }, { ptr, i64 } { ptr @tn.str.521, i64 18 }, { ptr, i64 } { ptr @tn.str.522, i64 7 }, { ptr, i64 } { ptr @tn.str.523, i64 6 }, { ptr, i64 } { ptr @tn.str.524, i64 8 }, { ptr, i64 } { ptr @tn.str.525, i64 8 }, { ptr, i64 } { ptr @tn.str.526, i64 8 }, { ptr, i64 } { ptr @tn.str.527, i64 4 }, { ptr, i64 } { ptr @tn.str.528, i64 5 }, { ptr, i64 } { ptr @tn.str.529, i64 5 }, { ptr, i64 } { ptr @tn.str.530, i64 7 }, { ptr, i64 } { ptr @tn.str.531, i64 10 }, { ptr, i64 } { ptr @tn.str.532, i64 3 }, { ptr, i64 } { ptr @tn.str.533, i64 13 }, { ptr, i64 } { ptr @tn.str.534, i64 14 }, { ptr, i64 } { ptr @tn.str.535, i64 4 }, { ptr, i64 } { ptr @tn.str.536, i64 8 }, { ptr, i64 } { ptr @tn.str.537, i64 9 }, { ptr, i64 } { ptr @tn.str.538, i64 4 }, { ptr, i64 } { ptr @tn.str.539, i64 9 }, { ptr, i64 } { ptr @tn.str.540, i64 5 }, { ptr, i64 } { ptr @tn.str.541, i64 6 }, { ptr, i64 } { ptr @tn.str.542, i64 5 }, { ptr, i64 } { ptr @tn.str.543, i64 6 }, { ptr, i64 } { ptr @tn.str.544, i64 8 }, { ptr, i64 } { ptr @tn.str.545, i64 6 }, { ptr, i64 } { ptr @tn.str.546, i64 9 }, { ptr, i64 } { ptr @tn.str.547, i64 7 }, { ptr, i64 } { ptr @tn.str.548, i64 4 }, { ptr, i64 } { ptr @tn.str.549, i64 4 }, { ptr, i64 } { ptr @tn.str.550, i64 5 }, { ptr, i64 } { ptr @tn.str.551, i64 16 }, { ptr, i64 } { ptr @tn.str.552, i64 14 }, { ptr, i64 } { ptr @tn.str.553, i64 21 }, { ptr, i64 } { ptr @tn.str.554, i64 6 }, { ptr, i64 } { ptr @tn.str.555, i64 7 }, { ptr, i64 } { ptr @tn.str.556, i64 24 }, { ptr, i64 } { ptr @tn.str.557, i64 23 }, { ptr, i64 } { ptr @tn.str.558, i64 15 }, { ptr, i64 } { ptr @tn.str.559, i64 12 }, { ptr, i64 } { ptr @tn.str.560, i64 12 }, { ptr, i64 } { ptr @tn.str.561, i64 10 }, { ptr, i64 } { ptr @tn.str.562, i64 4 }, { ptr, i64 } { ptr @tn.str.563, i64 8 }, { ptr, i64 } { ptr @tn.str.564, i64 8 }, { ptr, i64 } { ptr @tn.str.565, i64 10 }, { ptr, i64 } { ptr @tn.str.566, i64 7 }, { ptr, i64 } { ptr @tn.str.567, i64 9 }, { ptr, i64 } { ptr @tn.str.568, i64 4 }, { ptr, i64 } { ptr @tn.str.569, i64 13 }, { ptr, i64 } { ptr @tn.str.570, i64 6 }, { ptr, i64 } { ptr @tn.str.571, i64 7 }, { ptr, i64 } { ptr @tn.str.572, i64 18 }, { ptr, i64 } { ptr @tn.str.573, i64 9 }, { ptr, i64 } { ptr @tn.str.574, i64 5 }, { ptr, i64 } { ptr @tn.str.575, i64 6 }, { ptr, i64 } { ptr @tn.str.576, i64 6 }, { ptr, i64 } { ptr @tn.str.577, i64 6 }, { ptr, i64 } { ptr @tn.str.578, i64 7 }, { ptr, i64 } { ptr @tn.str.579, i64 7 }, { ptr, i64 } { ptr @tn.str.580, i64 7 }, { ptr, i64 } { ptr @tn.str.581, i64 7 }, { ptr, i64 } { ptr @tn.str.582, i64 4 }, { ptr, i64 } { ptr @tn.str.583, i64 4 }, { ptr, i64 } { ptr @tn.str.584, i64 5 }, { ptr, i64 } { ptr @tn.str.585, i64 12 }, { ptr, i64 } { ptr @tn.str.586, i64 6 }, { ptr, i64 } { ptr @tn.str.587, i64 7 }, { ptr, i64 } { ptr @tn.str.588, i64 5 }, { ptr, i64 } { ptr @tn.str.589, i64 4 }, { ptr, i64 } { ptr @tn.str.590, i64 6 }, { ptr, i64 } { ptr @tn.str.591, i64 5 }, { ptr, i64 } { ptr @tn.str.592, i64 6 }, { ptr, i64 } { ptr @tn.str.593, i64 6 }, { ptr, i64 } { ptr @tn.str.594, i64 7 }, { ptr, i64 } { ptr @tn.str.595, i64 7 }, { ptr, i64 } { ptr @tn.str.596, i64 4 }, { ptr, i64 } { ptr @tn.str.597, i64 16 }, { ptr, i64 } { ptr @tn.str.598, i64 10 }, { ptr, i64 } { ptr @tn.str.599, i64 8 }, { ptr, i64 } { ptr @tn.str.600, i64 11 }, { ptr, i64 } { ptr @tn.str.601, i64 14 }, { ptr, i64 } { ptr @tn.str.602, i64 7 }, { ptr, i64 } { ptr @tn.str.603, i64 13 }, { ptr, i64 } { ptr @tn.str.604, i64 9 }, { ptr, i64 } { ptr @tn.str.605, i64 8 }, { ptr, i64 } { ptr @tn.str.606, i64 10 }, { ptr, i64 } { ptr @tn.str.607, i64 5 }, { ptr, i64 } { ptr @tn.str.608, i64 5 }, { ptr, i64 } { ptr @tn.str.609, i64 9 }, { ptr, i64 } { ptr @tn.str.610, i64 9 }, { ptr, i64 } { ptr @tn.str.611, i64 6 }, { ptr, i64 } { ptr @tn.str.612, i64 16 }, { ptr, i64 } { ptr @tn.str.613, i64 13 }, { ptr, i64 } { ptr @tn.str.614, i64 14 }, { ptr, i64 } { ptr @tn.str.615, i64 7 }, { ptr, i64 } { ptr @tn.str.616, i64 7 }, { ptr, i64 } { ptr @tn.str.617, i64 8 }, { ptr, i64 } { ptr @tn.str.618, i64 8 }, { ptr, i64 } { ptr @tn.str.619, i64 9 }, { ptr, i64 } { ptr @tn.str.620, i64 5 }, { ptr, i64 } { ptr @tn.str.621, i64 11 }, { ptr, i64 } { ptr @tn.str.622, i64 10 }, { ptr, i64 } { ptr @tn.str.623, i64 5 }, { ptr, i64 } { ptr @tn.str.624, i64 12 }, { ptr, i64 } { ptr @tn.str.625, i64 7 }, { ptr, i64 } { ptr @tn.str.626, i64 6 }, { ptr, i64 } { ptr @tn.str.627, i64 10 }, { ptr, i64 } { ptr @tn.str.628, i64 19 }, { ptr, i64 } { ptr @tn.str.629, i64 6 }, { ptr, i64 } { ptr @tn.str.630, i64 4 }, { ptr, i64 } { ptr @tn.str.631, i64 5 }, { ptr, i64 } { ptr @tn.str.632, i64 10 }, { ptr, i64 } { ptr @tn.str.633, i64 5 }, { ptr, i64 } { ptr @tn.str.634, i64 9 }, { ptr, i64 } { ptr @tn.str.635, i64 7 }, { ptr, i64 } { ptr @tn.str.636, i64 10 }, { ptr, i64 } { ptr @tn.str.637, i64 8 }, { ptr, i64 } { ptr @tn.str.638, i64 6 }, { ptr, i64 } { ptr @tn.str.639, i64 8 }, { ptr, i64 } { ptr @tn.str.640, i64 5 }, { ptr, i64 } { ptr @tn.str.641, i64 8 }, { ptr, i64 } { ptr @tn.str.642, i64 6 }, { ptr, i64 } { ptr @tn.str.643, i64 8 }, { ptr, i64 } { ptr @tn.str.644, i64 13 }, { ptr, i64 } { ptr @tn.str.645, i64 7 }, { ptr, i64 } { ptr @tn.str.646, i64 8 }, { ptr, i64 } { ptr @tn.str.647, i64 5 }, { ptr, i64 } { ptr @tn.str.648, i64 7 }, { ptr, i64 } { ptr @tn.str.649, i64 6 }, { ptr, i64 } { ptr @tn.str.650, i64 7 }, { ptr, i64 } { ptr @tn.str.651, i64 8 }, { ptr, i64 } { ptr @tn.str.652, i64 6 }, { ptr, i64 } { ptr @tn.str.653, i64 8 }, { ptr, i64 } { ptr @tn.str.654, i64 15 }, { ptr, i64 } { ptr @tn.str.655, i64 8 }] @str.656 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.657 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.658 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.659 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.660 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.661 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.662 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.657 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.658 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.659 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.660 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.661 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.662 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 @str.663 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 @str.664 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.665 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.666 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.669 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.670 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.672 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 -@str.673 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.674 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 -@str.675 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 -@str.676 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.677 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 -@str.678 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 -@str.679 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.680 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 -@str.681 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.682 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.683 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.684 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.666 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.667 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.668 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.669 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.671 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.672 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.674 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.675 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.676 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.677 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 +@str.678 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.679 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 +@str.680 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 +@str.681 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.682 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 +@str.683 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 +@str.684 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.685 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 +@str.686 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.687 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.688 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.685 = private constant [5 x i8] c"line\00" -@fld.str.686 = private constant [4 x i8] c"col\00" -@fld.str.687 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.685, i64 4 }, { ptr, i64 } { ptr @fld.str.686, i64 3 }, { ptr, i64 } { ptr @fld.str.687, i64 4 }] -@str.688 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.689 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.690 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.691 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.693 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.694 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.695 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.696 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.697 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.698 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.699 = private constant [12 x i8] c"alloc_count\00" -@field_names.700 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.699, i64 11 }] -@str.701 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.702 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.703 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.704 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.705 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.706 = private constant [5 x i8] c"next\00" -@fld.str.707 = private constant [4 x i8] c"cap\00" -@field_names.708 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.706, i64 4 }, { ptr, i64 } { ptr @fld.str.707, i64 3 }] -@str.709 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.710 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.711 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.712 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.713 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.714 = private constant [4 x i8] c"ctx\00" -@fld.str.715 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.716 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.717 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.714, i64 3 }, { ptr, i64 } { ptr @fld.str.715, i64 11 }, { ptr, i64 } { ptr @fld.str.716, i64 13 }] -@str.718 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.719 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.720 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.721 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.722 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.723 = private constant [6 x i8] c"first\00" -@fld.str.724 = private constant [10 x i8] c"end_index\00" -@fld.str.725 = private constant [7 x i8] c"parent\00" -@field_names.726 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.723, i64 5 }, { ptr, i64 } { ptr @fld.str.724, i64 9 }, { ptr, i64 } { ptr @fld.str.725, i64 6 }] -@str.727 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.728 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.729 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.730 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.731 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.732 = private constant [4 x i8] c"buf\00" -@fld.str.733 = private constant [4 x i8] c"len\00" -@fld.str.734 = private constant [4 x i8] c"pos\00" -@field_names.735 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.732, i64 3 }, { ptr, i64 } { ptr @fld.str.733, i64 3 }, { ptr, i64 } { ptr @fld.str.734, i64 3 }] -@str.736 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.737 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.738 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.739 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.740 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.741 = private constant [7 x i8] c"parent\00" -@fld.str.742 = private constant [12 x i8] c"alloc_count\00" -@fld.str.743 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.744 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.745 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.741, i64 6 }, { ptr, i64 } { ptr @fld.str.742, i64 11 }, { ptr, i64 } { ptr @fld.str.743, i64 13 }, { ptr, i64 } { ptr @fld.str.744, i64 17 }] -@str.746 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.747 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.748 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.749 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.750 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.751 = private constant [10 x i8] c"allocator\00" -@fld.str.752 = private constant [5 x i8] c"data\00" -@field_names.753 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.751, i64 9 }, { ptr, i64 } { ptr @fld.str.752, i64 4 }] -@str.754 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.755 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.756 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.757 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.758 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.759 = private constant [3 x i8] c"fd\00" -@field_names.760 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.759, i64 2 }] -@str.761 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.762 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.763 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.764 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.765 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.766 = private constant [5 x i8] c"file\00" -@fld.str.767 = private constant [5 x i8] c"line\00" -@fld.str.768 = private constant [4 x i8] c"col\00" -@fld.str.769 = private constant [5 x i8] c"func\00" -@fld.str.770 = private constant [10 x i8] c"line_text\00" -@field_names.771 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.766, i64 4 }, { ptr, i64 } { ptr @fld.str.767, i64 4 }, { ptr, i64 } { ptr @fld.str.768, i64 3 }, { ptr, i64 } { ptr @fld.str.769, i64 4 }, { ptr, i64 } { ptr @fld.str.770, i64 9 }] -@str.772 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.773 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.774 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.775 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.776 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.777 = private constant [10 x i8] c"exit_code\00" -@fld.str.778 = private constant [7 x i8] c"stdout\00" -@field_names.779 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.777, i64 9 }, { ptr, i64 } { ptr @fld.str.778, i64 6 }] -@str.780 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.781 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.782 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.783 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.784 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.785 = private constant [8 x i8] c"sin_len\00" -@fld.str.786 = private constant [11 x i8] c"sin_family\00" -@fld.str.787 = private constant [9 x i8] c"sin_port\00" -@fld.str.788 = private constant [9 x i8] c"sin_addr\00" -@fld.str.789 = private constant [9 x i8] c"sin_zero\00" -@field_names.790 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.785, i64 7 }, { ptr, i64 } { ptr @fld.str.786, i64 10 }, { ptr, i64 } { ptr @fld.str.787, i64 8 }, { ptr, i64 } { ptr @fld.str.788, i64 8 }, { ptr, i64 } { ptr @fld.str.789, i64 8 }] -@str.791 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.792 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.793 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.794 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.795 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.796 = private constant [6 x i8] c"items\00" -@fld.str.797 = private constant [4 x i8] c"len\00" -@fld.str.798 = private constant [4 x i8] c"cap\00" -@field_names.799 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.796, i64 5 }, { ptr, i64 } { ptr @fld.str.797, i64 3 }, { ptr, i64 } { ptr @fld.str.798, i64 3 }] -@str.800 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.801 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.802 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.803 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.804 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.805 = private constant [6 x i8] c"items\00" -@fld.str.806 = private constant [4 x i8] c"len\00" -@fld.str.807 = private constant [4 x i8] c"cap\00" -@field_names.808 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.805, i64 5 }, { ptr, i64 } { ptr @fld.str.806, i64 3 }, { ptr, i64 } { ptr @fld.str.807, i64 3 }] -@str.809 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.810 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.811 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.812 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.813 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.814 = private constant [4 x i8] c"key\00" -@fld.str.815 = private constant [4 x i8] c"val\00" -@field_names.816 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.814, i64 3 }, { ptr, i64 } { ptr @fld.str.815, i64 3 }] -@str.817 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.818 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.819 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.820 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.821 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.822 = private constant [4 x i8] c"dst\00" -@fld.str.823 = private constant [4 x i8] c"pos\00" -@fld.str.824 = private constant [5 x i8] c"file\00" -@field_names.825 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.822, i64 3 }, { ptr, i64 } { ptr @fld.str.823, i64 3 }, { ptr, i64 } { ptr @fld.str.824, i64 4 }] -@str.826 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.827 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.828 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.829 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.830 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.831 = private constant [4 x i8] c"src\00" -@fld.str.832 = private constant [4 x i8] c"pos\00" -@fld.str.833 = private constant [6 x i8] c"alloc\00" -@field_names.834 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.831, i64 3 }, { ptr, i64 } { ptr @fld.str.832, i64 3 }, { ptr, i64 } { ptr @fld.str.833, i64 5 }] -@str.835 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.836 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.837 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.838 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.839 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.840 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.841 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.842 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.843 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.844 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.845 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.846 = private constant [5 x i8] c"name\00" -@fld.str.847 = private constant [12 x i8] c"takes_value\00" -@fld.str.848 = private constant [9 x i8] c"required\00" -@field_names.849 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.846, i64 4 }, { ptr, i64 } { ptr @fld.str.847, i64 11 }, { ptr, i64 } { ptr @fld.str.848, i64 8 }] -@str.850 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.851 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.852 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.853 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.854 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.855 = private constant [6 x i8] c"group\00" -@fld.str.856 = private constant [8 x i8] c"command\00" -@fld.str.857 = private constant [6 x i8] c"flags\00" -@field_names.858 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.855, i64 5 }, { ptr, i64 } { ptr @fld.str.856, i64 7 }, { ptr, i64 } { ptr @fld.str.857, i64 5 }] -@str.859 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.860 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.861 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.862 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.863 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.864 = private constant [4 x i8] c"set\00" -@fld.str.865 = private constant [6 x i8] c"value\00" -@field_names.866 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.864, i64 3 }, { ptr, i64 } { ptr @fld.str.865, i64 5 }] -@str.867 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.868 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.869 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.870 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.871 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.872 = private constant [6 x i8] c"index\00" -@fld.str.873 = private constant [6 x i8] c"token\00" -@field_names.874 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.872, i64 5 }, { ptr, i64 } { ptr @fld.str.873, i64 5 }] -@str.875 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.876 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.877 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.878 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.879 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.880 = private constant [6 x i8] c"group\00" -@fld.str.881 = private constant [8 x i8] c"command\00" -@fld.str.882 = private constant [10 x i8] c"cmd_index\00" -@fld.str.883 = private constant [5 x i8] c"json\00" -@fld.str.884 = private constant [5 x i8] c"rest\00" -@fld.str.885 = private constant [5 x i8] c"spec\00" -@fld.str.886 = private constant [7 x i8] c"values\00" -@field_names.887 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.880, i64 5 }, { ptr, i64 } { ptr @fld.str.881, i64 7 }, { ptr, i64 } { ptr @fld.str.882, i64 9 }, { ptr, i64 } { ptr @fld.str.883, i64 4 }, { ptr, i64 } { ptr @fld.str.884, i64 4 }, { ptr, i64 } { ptr @fld.str.885, i64 4 }, { ptr, i64 } { ptr @fld.str.886, i64 6 }] -@str.888 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.889 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.890 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.891 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.892 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.893 = private constant [2 x i8] c"h\00" -@fld.str.894 = private constant [4 x i8] c"buf\00" -@fld.str.895 = private constant [8 x i8] c"buf_len\00" -@fld.str.896 = private constant [10 x i8] c"total_len\00" -@field_names.897 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.893, i64 1 }, { ptr, i64 } { ptr @fld.str.894, i64 3 }, { ptr, i64 } { ptr @fld.str.895, i64 7 }, { ptr, i64 } { ptr @fld.str.896, i64 9 }] -@str.898 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.899 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 -@str.900 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.901 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.902 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.903 = private constant [5 x i8] c"data\00" -@field_names.904 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.903, i64 4 }] -@str.905 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.906 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 -@str.907 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.908 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.909 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.910 = private constant [2 x i8] c"x\00" -@fld.str.911 = private constant [2 x i8] c"y\00" -@field_names.912 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.910, i64 1 }, { ptr, i64 } { ptr @fld.str.911, i64 1 }] -@str.913 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.914 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 -@str.915 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.916 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.917 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.918 = private constant [2 x i8] c"x\00" -@fld.str.919 = private constant [2 x i8] c"y\00" -@field_names.920 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.918, i64 1 }, { ptr, i64 } { ptr @fld.str.919, i64 1 }] -@str.921 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.922 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.923 = private constant [5 x i8] c"read\00" -@fld.str.924 = private constant [6 x i8] c"write\00" -@fld.str.925 = private constant [7 x i8] c"append\00" -@fld.str.926 = private constant [11 x i8] c"read_write\00" -@field_names.927 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.923, i64 4 }, { ptr, i64 } { ptr @fld.str.924, i64 5 }, { ptr, i64 } { ptr @fld.str.925, i64 6 }, { ptr, i64 } { ptr @fld.str.926, i64 10 }] -@str.928 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.929 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.930 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.931 = private constant [4 x i8] c"set\00" -@fld.str.932 = private constant [8 x i8] c"current\00" -@fld.str.933 = private constant [4 x i8] c"end\00" -@field_names.934 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.931, i64 3 }, { ptr, i64 } { ptr @fld.str.932, i64 7 }, { ptr, i64 } { ptr @fld.str.933, i64 3 }] -@str.935 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.936 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.937 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.938 = private constant [6 x i8] c"null_\00" -@fld.str.939 = private constant [6 x i8] c"bool_\00" -@fld.str.940 = private constant [5 x i8] c"int_\00" -@fld.str.941 = private constant [4 x i8] c"str\00" -@fld.str.942 = private constant [6 x i8] c"array\00" -@fld.str.943 = private constant [7 x i8] c"object\00" -@field_names.944 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.938, i64 5 }, { ptr, i64 } { ptr @fld.str.939, i64 5 }, { ptr, i64 } { ptr @fld.str.940, i64 4 }, { ptr, i64 } { ptr @fld.str.941, i64 3 }, { ptr, i64 } { ptr @fld.str.942, i64 5 }, { ptr, i64 } { ptr @fld.str.943, i64 6 }] -@str.945 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.946 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.947 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.948 = private constant [6 x i8] c"macos\00" -@fld.str.949 = private constant [6 x i8] c"linux\00" -@fld.str.950 = private constant [8 x i8] c"windows\00" -@fld.str.951 = private constant [5 x i8] c"wasm\00" -@fld.str.952 = private constant [4 x i8] c"ios\00" -@fld.str.953 = private constant [8 x i8] c"android\00" -@fld.str.954 = private constant [8 x i8] c"unknown\00" -@field_names.955 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.948, i64 5 }, { ptr, i64 } { ptr @fld.str.949, i64 5 }, { ptr, i64 } { ptr @fld.str.950, i64 7 }, { ptr, i64 } { ptr @fld.str.951, i64 4 }, { ptr, i64 } { ptr @fld.str.952, i64 3 }, { ptr, i64 } { ptr @fld.str.953, i64 7 }, { ptr, i64 } { ptr @fld.str.954, i64 7 }] -@str.956 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.957 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.958 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.959 = private constant [8 x i8] c"aarch64\00" -@fld.str.960 = private constant [7 x i8] c"x86_64\00" -@fld.str.961 = private constant [7 x i8] c"wasm32\00" -@fld.str.962 = private constant [7 x i8] c"wasm64\00" -@fld.str.963 = private constant [8 x i8] c"unknown\00" -@field_names.964 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.959, i64 7 }, { ptr, i64 } { ptr @fld.str.960, i64 6 }, { ptr, i64 } { ptr @fld.str.961, i64 6 }, { ptr, i64 } { ptr @fld.str.962, i64 6 }, { ptr, i64 } { ptr @fld.str.963, i64 7 }] -@str.965 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.966 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.967 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.968 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.969 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.970 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.971 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.972 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.973 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.974 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.975 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.976 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.977 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.978 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.979 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.980 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.981 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.982 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.983 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.984 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.985 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.986 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.987 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.988 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.989 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.990 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.991 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.992 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.993 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.994 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.995 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.996 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.997 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.998 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.999 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1000 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1001 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1002 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1003 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1004 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.1005 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1006 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1007 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.1008 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1009 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1010 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.1011 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1012 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1013 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.1014 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1015 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1016 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.1017 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1018 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1019 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.1020 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1021 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1022 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.1023 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1024 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1025 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.1026 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1027 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1028 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.1029 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1030 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1031 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.1032 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1033 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1034 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.1035 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1036 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1037 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.1038 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1039 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1040 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.1041 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1042 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1043 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.1044 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1045 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1046 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.1047 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1048 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1049 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.1050 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1051 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1052 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.1053 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1054 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1055 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.1056 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1057 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1058 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.1059 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1060 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1061 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.1062 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1063 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1064 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.1065 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1066 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1067 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.1068 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1069 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1070 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.1071 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1072 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1073 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.1074 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1075 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1076 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.1077 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1078 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1079 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.1080 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1081 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1082 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.1083 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1084 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1085 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.1086 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1087 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1088 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.1089 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1090 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1091 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 -@str.1092 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1093 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1094 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.1095 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1096 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1097 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.690 = private constant [5 x i8] c"line\00" +@fld.str.691 = private constant [4 x i8] c"col\00" +@fld.str.692 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.690, i64 4 }, { ptr, i64 } { ptr @fld.str.691, i64 3 }, { ptr, i64 } { ptr @fld.str.692, i64 4 }] +@str.693 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.694 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.695 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.696 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.698 = private constant [4 x i8] c"ctx\00" +@fld.str.699 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.700 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.701 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.698, i64 3 }, { ptr, i64 } { ptr @fld.str.699, i64 11 }, { ptr, i64 } { ptr @fld.str.700, i64 13 }] +@str.702 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.703 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.704 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.705 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.706 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.707 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.708 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.710 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.711 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.712 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.713 = private constant [12 x i8] c"alloc_count\00" +@field_names.714 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.713, i64 11 }] +@str.715 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.716 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.717 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.718 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.719 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.720 = private constant [5 x i8] c"next\00" +@fld.str.721 = private constant [4 x i8] c"cap\00" +@field_names.722 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.720, i64 4 }, { ptr, i64 } { ptr @fld.str.721, i64 3 }] +@str.723 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.724 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.725 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.726 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.727 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.728 = private constant [6 x i8] c"first\00" +@fld.str.729 = private constant [10 x i8] c"end_index\00" +@fld.str.730 = private constant [7 x i8] c"parent\00" +@field_names.731 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.728, i64 5 }, { ptr, i64 } { ptr @fld.str.729, i64 9 }, { ptr, i64 } { ptr @fld.str.730, i64 6 }] +@str.732 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.733 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.734 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.735 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.736 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.737 = private constant [4 x i8] c"buf\00" +@fld.str.738 = private constant [4 x i8] c"len\00" +@fld.str.739 = private constant [4 x i8] c"pos\00" +@field_names.740 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.737, i64 3 }, { ptr, i64 } { ptr @fld.str.738, i64 3 }, { ptr, i64 } { ptr @fld.str.739, i64 3 }] +@str.741 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.742 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.743 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.744 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.745 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.746 = private constant [7 x i8] c"parent\00" +@fld.str.747 = private constant [12 x i8] c"alloc_count\00" +@fld.str.748 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.749 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.750 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.746, i64 6 }, { ptr, i64 } { ptr @fld.str.747, i64 11 }, { ptr, i64 } { ptr @fld.str.748, i64 13 }, { ptr, i64 } { ptr @fld.str.749, i64 17 }] +@str.751 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.752 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.753 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.754 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.755 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.756 = private constant [10 x i8] c"allocator\00" +@fld.str.757 = private constant [5 x i8] c"data\00" +@field_names.758 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.756, i64 9 }, { ptr, i64 } { ptr @fld.str.757, i64 4 }] +@str.759 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.760 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.761 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.762 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.763 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.764 = private constant [3 x i8] c"fd\00" +@field_names.765 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.764, i64 2 }] +@str.766 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.767 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.768 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.769 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.770 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.771 = private constant [5 x i8] c"file\00" +@fld.str.772 = private constant [5 x i8] c"line\00" +@fld.str.773 = private constant [4 x i8] c"col\00" +@fld.str.774 = private constant [5 x i8] c"func\00" +@fld.str.775 = private constant [10 x i8] c"line_text\00" +@field_names.776 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.771, i64 4 }, { ptr, i64 } { ptr @fld.str.772, i64 4 }, { ptr, i64 } { ptr @fld.str.773, i64 3 }, { ptr, i64 } { ptr @fld.str.774, i64 4 }, { ptr, i64 } { ptr @fld.str.775, i64 9 }] +@str.777 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.778 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.779 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.780 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.781 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.782 = private constant [10 x i8] c"exit_code\00" +@fld.str.783 = private constant [7 x i8] c"stdout\00" +@field_names.784 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.782, i64 9 }, { ptr, i64 } { ptr @fld.str.783, i64 6 }] +@str.785 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.786 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.787 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.788 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.789 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.790 = private constant [8 x i8] c"sin_len\00" +@fld.str.791 = private constant [11 x i8] c"sin_family\00" +@fld.str.792 = private constant [9 x i8] c"sin_port\00" +@fld.str.793 = private constant [9 x i8] c"sin_addr\00" +@fld.str.794 = private constant [9 x i8] c"sin_zero\00" +@field_names.795 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.790, i64 7 }, { ptr, i64 } { ptr @fld.str.791, i64 10 }, { ptr, i64 } { ptr @fld.str.792, i64 8 }, { ptr, i64 } { ptr @fld.str.793, i64 8 }, { ptr, i64 } { ptr @fld.str.794, i64 8 }] +@str.796 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.797 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.798 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.799 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.800 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.801 = private constant [6 x i8] c"items\00" +@fld.str.802 = private constant [4 x i8] c"len\00" +@fld.str.803 = private constant [4 x i8] c"cap\00" +@field_names.804 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.801, i64 5 }, { ptr, i64 } { ptr @fld.str.802, i64 3 }, { ptr, i64 } { ptr @fld.str.803, i64 3 }] +@str.805 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.806 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.807 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.808 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.809 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.810 = private constant [6 x i8] c"items\00" +@fld.str.811 = private constant [4 x i8] c"len\00" +@fld.str.812 = private constant [4 x i8] c"cap\00" +@field_names.813 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.810, i64 5 }, { ptr, i64 } { ptr @fld.str.811, i64 3 }, { ptr, i64 } { ptr @fld.str.812, i64 3 }] +@str.814 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.815 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.816 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.817 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.818 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.819 = private constant [4 x i8] c"key\00" +@fld.str.820 = private constant [4 x i8] c"val\00" +@field_names.821 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.819, i64 3 }, { ptr, i64 } { ptr @fld.str.820, i64 3 }] +@str.822 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.823 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.824 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.825 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.826 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.827 = private constant [4 x i8] c"dst\00" +@fld.str.828 = private constant [4 x i8] c"pos\00" +@fld.str.829 = private constant [5 x i8] c"file\00" +@field_names.830 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.827, i64 3 }, { ptr, i64 } { ptr @fld.str.828, i64 3 }, { ptr, i64 } { ptr @fld.str.829, i64 4 }] +@str.831 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.832 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.833 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.834 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.835 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.836 = private constant [4 x i8] c"src\00" +@fld.str.837 = private constant [4 x i8] c"pos\00" +@fld.str.838 = private constant [6 x i8] c"alloc\00" +@field_names.839 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.836, i64 3 }, { ptr, i64 } { ptr @fld.str.837, i64 3 }, { ptr, i64 } { ptr @fld.str.838, i64 5 }] +@str.840 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.841 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.842 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.843 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.844 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.845 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.846 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.847 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.848 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.849 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.850 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.851 = private constant [5 x i8] c"name\00" +@fld.str.852 = private constant [12 x i8] c"takes_value\00" +@fld.str.853 = private constant [9 x i8] c"required\00" +@field_names.854 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.851, i64 4 }, { ptr, i64 } { ptr @fld.str.852, i64 11 }, { ptr, i64 } { ptr @fld.str.853, i64 8 }] +@str.855 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.856 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.857 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.858 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.859 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.860 = private constant [6 x i8] c"group\00" +@fld.str.861 = private constant [8 x i8] c"command\00" +@fld.str.862 = private constant [6 x i8] c"flags\00" +@field_names.863 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.860, i64 5 }, { ptr, i64 } { ptr @fld.str.861, i64 7 }, { ptr, i64 } { ptr @fld.str.862, i64 5 }] +@str.864 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.865 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.866 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.867 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.868 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.869 = private constant [4 x i8] c"set\00" +@fld.str.870 = private constant [6 x i8] c"value\00" +@field_names.871 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.869, i64 3 }, { ptr, i64 } { ptr @fld.str.870, i64 5 }] +@str.872 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.873 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.874 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.875 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.876 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.877 = private constant [6 x i8] c"index\00" +@fld.str.878 = private constant [6 x i8] c"token\00" +@field_names.879 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.877, i64 5 }, { ptr, i64 } { ptr @fld.str.878, i64 5 }] +@str.880 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.881 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.882 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.883 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.884 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.885 = private constant [6 x i8] c"group\00" +@fld.str.886 = private constant [8 x i8] c"command\00" +@fld.str.887 = private constant [10 x i8] c"cmd_index\00" +@fld.str.888 = private constant [5 x i8] c"json\00" +@fld.str.889 = private constant [5 x i8] c"rest\00" +@fld.str.890 = private constant [5 x i8] c"spec\00" +@fld.str.891 = private constant [7 x i8] c"values\00" +@field_names.892 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.885, i64 5 }, { ptr, i64 } { ptr @fld.str.886, i64 7 }, { ptr, i64 } { ptr @fld.str.887, i64 9 }, { ptr, i64 } { ptr @fld.str.888, i64 4 }, { ptr, i64 } { ptr @fld.str.889, i64 4 }, { ptr, i64 } { ptr @fld.str.890, i64 4 }, { ptr, i64 } { ptr @fld.str.891, i64 6 }] +@str.893 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.894 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.895 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.896 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.897 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.898 = private constant [2 x i8] c"h\00" +@fld.str.899 = private constant [4 x i8] c"buf\00" +@fld.str.900 = private constant [8 x i8] c"buf_len\00" +@fld.str.901 = private constant [10 x i8] c"total_len\00" +@field_names.902 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.898, i64 1 }, { ptr, i64 } { ptr @fld.str.899, i64 3 }, { ptr, i64 } { ptr @fld.str.900, i64 7 }, { ptr, i64 } { ptr @fld.str.901, i64 9 }] +@str.903 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.904 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.905 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.906 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.907 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.908 = private constant [5 x i8] c"data\00" +@field_names.909 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.908, i64 4 }] +@str.910 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.911 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.912 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.913 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.914 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.915 = private constant [2 x i8] c"x\00" +@fld.str.916 = private constant [2 x i8] c"y\00" +@field_names.917 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.915, i64 1 }, { ptr, i64 } { ptr @fld.str.916, i64 1 }] +@str.918 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.919 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.920 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.921 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.922 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.923 = private constant [2 x i8] c"x\00" +@fld.str.924 = private constant [2 x i8] c"y\00" +@field_names.925 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.923, i64 1 }, { ptr, i64 } { ptr @fld.str.924, i64 1 }] +@str.926 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.927 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.928 = private constant [5 x i8] c"read\00" +@fld.str.929 = private constant [6 x i8] c"write\00" +@fld.str.930 = private constant [7 x i8] c"append\00" +@fld.str.931 = private constant [11 x i8] c"read_write\00" +@field_names.932 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.928, i64 4 }, { ptr, i64 } { ptr @fld.str.929, i64 5 }, { ptr, i64 } { ptr @fld.str.930, i64 6 }, { ptr, i64 } { ptr @fld.str.931, i64 10 }] +@str.933 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.934 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.935 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.936 = private constant [4 x i8] c"set\00" +@fld.str.937 = private constant [8 x i8] c"current\00" +@fld.str.938 = private constant [4 x i8] c"end\00" +@field_names.939 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.936, i64 3 }, { ptr, i64 } { ptr @fld.str.937, i64 7 }, { ptr, i64 } { ptr @fld.str.938, i64 3 }] +@str.940 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.941 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.942 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.943 = private constant [6 x i8] c"null_\00" +@fld.str.944 = private constant [6 x i8] c"bool_\00" +@fld.str.945 = private constant [5 x i8] c"int_\00" +@fld.str.946 = private constant [4 x i8] c"str\00" +@fld.str.947 = private constant [6 x i8] c"array\00" +@fld.str.948 = private constant [7 x i8] c"object\00" +@field_names.949 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.943, i64 5 }, { ptr, i64 } { ptr @fld.str.944, i64 5 }, { ptr, i64 } { ptr @fld.str.945, i64 4 }, { ptr, i64 } { ptr @fld.str.946, i64 3 }, { ptr, i64 } { ptr @fld.str.947, i64 5 }, { ptr, i64 } { ptr @fld.str.948, i64 6 }] +@str.950 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.951 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.952 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.953 = private constant [6 x i8] c"macos\00" +@fld.str.954 = private constant [6 x i8] c"linux\00" +@fld.str.955 = private constant [8 x i8] c"windows\00" +@fld.str.956 = private constant [5 x i8] c"wasm\00" +@fld.str.957 = private constant [4 x i8] c"ios\00" +@fld.str.958 = private constant [8 x i8] c"android\00" +@fld.str.959 = private constant [8 x i8] c"unknown\00" +@field_names.960 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.953, i64 5 }, { ptr, i64 } { ptr @fld.str.954, i64 5 }, { ptr, i64 } { ptr @fld.str.955, i64 7 }, { ptr, i64 } { ptr @fld.str.956, i64 4 }, { ptr, i64 } { ptr @fld.str.957, i64 3 }, { ptr, i64 } { ptr @fld.str.958, i64 7 }, { ptr, i64 } { ptr @fld.str.959, i64 7 }] +@str.961 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.962 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.963 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.964 = private constant [8 x i8] c"aarch64\00" +@fld.str.965 = private constant [7 x i8] c"x86_64\00" +@fld.str.966 = private constant [7 x i8] c"wasm32\00" +@fld.str.967 = private constant [7 x i8] c"wasm64\00" +@fld.str.968 = private constant [8 x i8] c"unknown\00" +@field_names.969 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.964, i64 7 }, { ptr, i64 } { ptr @fld.str.965, i64 6 }, { ptr, i64 } { ptr @fld.str.966, i64 6 }, { ptr, i64 } { ptr @fld.str.967, i64 6 }, { ptr, i64 } { ptr @fld.str.968, i64 7 }] +@str.970 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.971 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.972 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.973 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.974 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.975 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.976 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.977 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.978 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.979 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.980 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.981 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.982 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.983 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.984 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.985 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.986 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.987 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.988 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.989 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.990 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.991 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.992 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.993 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.994 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.995 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.996 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.997 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.998 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.999 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1000 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1001 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1002 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1003 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1004 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1005 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1006 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1007 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1008 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1009 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.1010 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1011 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1012 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.1013 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1014 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1015 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.1016 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1017 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1018 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.1019 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1020 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1021 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.1022 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1023 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1024 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.1025 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1026 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1027 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.1028 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1029 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1030 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.1031 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1032 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1033 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.1034 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1035 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1036 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.1037 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1038 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1039 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.1040 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1041 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1042 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.1043 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1044 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1045 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.1046 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1047 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1048 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.1049 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1050 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1051 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.1052 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1053 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1054 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.1055 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1056 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1057 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.1058 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1059 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1060 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.1061 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1062 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1063 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.1064 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1065 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1066 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.1067 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1068 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1069 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.1070 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1071 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1072 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.1073 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1074 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1075 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.1076 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1077 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1078 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.1079 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1080 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1081 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.1082 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1083 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1084 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.1085 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1086 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1087 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.1088 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1089 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1090 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.1091 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1092 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1093 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.1094 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1095 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1096 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 +@str.1097 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.1098 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1099 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1099 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.1100 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1101 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1102 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1103 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1104 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -655,6 +655,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -874,7 +877,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.465, i64 1 } + ret { ptr, i64 } { ptr @str.470, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1001,7 +1004,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.466, i64 4 }, %if.then.78 ], [ { ptr @str.467, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.471, i64 4 }, %if.then.78 ], [ { ptr @str.472, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1335,7 +1338,7 @@ entry: br i1 %icmp, label %if.then.393, label %if.merge.394 if.then.393: ; preds = %entry - ret { ptr, i64 } { ptr @str.468, i64 1 } + ret { ptr, i64 } { ptr @str.473, i64 1 } if.merge.394: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1485,7 +1488,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.469, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.474, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1511,9 +1514,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1558,9 +1561,9 @@ entry: i64 85, label %match.arm.48 i64 100, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1600,7 +1603,7 @@ match.merge.37: ; preds = %dispatch.merge.496, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.470, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.475, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1644,9 +1647,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1731,9 +1734,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.358 [ i64 18, label %dispatch.case.359 - i64 21, label %dispatch.case.360 - i64 23, label %dispatch.case.361 - i64 25, label %dispatch.case.362 + i64 22, label %dispatch.case.360 + i64 24, label %dispatch.case.361 + i64 26, label %dispatch.case.362 i64 28, label %dispatch.case.363 i64 29, label %dispatch.case.364 i64 31, label %dispatch.case.365 @@ -1831,7 +1834,7 @@ dispatch.merge.94: ; preds = %dispatch.case.123, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.651, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.656, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1845,32 +1848,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2064,7 +2067,7 @@ dispatch.merge.264: ; preds = %dispatch.case.270, br label %match.merge.37 dispatch.default.265: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.652, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.657, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.264 dispatch.case.266: ; preds = %match.arm.44 @@ -2105,7 +2108,7 @@ dispatch.merge.281: ; preds = %dispatch.case.289, br label %match.merge.37 dispatch.default.282: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.653, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.658, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.281 dispatch.case.283: ; preds = %match.arm.47 @@ -2170,7 +2173,7 @@ dispatch.merge.325: ; preds = %dispatch.case.331, br label %match.merge.37 dispatch.default.326: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.654, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.659, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.325 dispatch.case.327: ; preds = %match.arm.48 @@ -2219,7 +2222,7 @@ dispatch.merge.357: ; preds = %dispatch.case.389, br label %match.merge.37 dispatch.default.358: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.655, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.660, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.357 dispatch.case.359: ; preds = %match.arm.49 @@ -2445,7 +2448,7 @@ dispatch.merge.496: ; preds = %dispatch.case.501, br label %match.merge.37 dispatch.default.497: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.656, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.661, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.496 dispatch.case.498: ; preds = %match.arm.50 @@ -2487,7 +2490,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.657, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.662, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2583,7 +2586,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2591,7 +2594,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2601,13 +2604,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2615,7 +2618,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2629,7 +2632,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2637,7 +2640,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2648,7 +2651,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2705,7 +2708,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2713,7 +2716,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2724,7 +2727,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2744,7 +2747,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2752,7 +2755,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, 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 @@ -2763,7 +2766,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2773,64 +2776,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3006,163 +3012,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3360,64 +3369,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3447,97 +3456,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3576,7 +3585,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3645,1024 +3654,1033 @@ declare { float, float } @Vec2.negate(ptr, { float, float }) #0 declare i1 @Vec2.equals(ptr, { float, float }, { float, float }) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind -declare void @assert.162(ptr, i1) #0 +declare void @assert.164(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.163(ptr) #0 +declare void @out.165(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.164(ptr, ptr, i64) #0 +declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.165(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.166(ptr) #0 +declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.167(ptr, ptr, i64) #0 +declare i64 @GPA.init.169(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.169(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.170(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.171(ptr, ptr) #0 +declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.172(ptr, ptr) #0 +declare void @Arena.reset.174(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.173(ptr, ptr, i64) #0 +declare void @Arena.deinit.175(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.174(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.175(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.176(ptr, ptr) #0 +declare ptr @BufAlloc.init.178(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.177(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.178(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.179(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.180(ptr, ptr) #0 +declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.181(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.182(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.184(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.183(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @cstring.184(ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.185(ptr, i64) #0 +declare ptr @cstring.187(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.186(ptr, i64) #0 +declare ptr @int_to_string.188(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.187(ptr, i1) #0 +declare ptr @uint_to_string.189(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.188(ptr, double) #0 +declare ptr @bool_to_string.190(ptr, i1) #0 ; Function Attrs: nounwind -declare void @hex_group.189(ptr, ptr, i64, i64) #0 +declare ptr @float_to_string.191(ptr, double) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.190(ptr, i64) #0 +declare void @hex_group.192(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.191(ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @concat.192(ptr, ptr, ptr) #0 +declare ptr @int_to_hex_string.194(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.193(ptr, ptr, i64, i64) #0 +declare ptr @concat.195(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.194(ptr, ptr) #0 +declare ptr @substr.196(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.195(ptr, [2 x i64]) #0 +declare ptr @path_join.197(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.196(ptr, ptr) #0 +declare ptr @any_to_string.198(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.197(ptr, ptr, i64) #0 +declare ptr @build_format.199(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.198(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.199(ptr) #0 +declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.200(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.201(ptr, ptr, ptr) #0 +declare i64 @GPA.init.203(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.202(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.203(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.204(ptr, ptr) #0 +declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.205(ptr, ptr) #0 +declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.206(ptr, ptr, i64) #0 +declare void @Arena.reset.208(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.207(ptr, ptr, ptr) #0 +declare void @Arena.deinit.209(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.208(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.209(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.210(ptr, ptr, i64) #0 +declare ptr @BufAlloc.init.212(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.212(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.213(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.214(ptr, ptr) #0 +declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.215(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.216(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.218(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.217(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.218(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.219(ptr, i32, ...) #0 +declare ptr @escape.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.220(i32) #0 +declare void @log_emit.222(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.221(i32, ptr, i64) #0 +declare i32 @open.223(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.222(i32, i64, i32) #0 +declare i32 @close.224(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.223(ptr) #0 +declare i64 @read.225(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.224(ptr) #0 +declare i64 @lseek.226(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.225(ptr, i32) #0 +declare i32 @unlink.227(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.226(ptr, i32) #0 +declare i32 @rmdir.228(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.227(ptr, i32) #0 +declare i32 @mkdir.229(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.228(ptr, ptr) #0 +declare i32 @access.230(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.229(ptr, ptr) #0 +declare i32 @chmod.231(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.230(ptr, ptr) #0 +declare i32 @rename.232(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.231(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.233(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.232(ptr, ptr, ptr) #0 +declare i1 @File.close.234(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.233(ptr, ptr, i64, i64) #0 +declare i64 @File.read.235(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.234(ptr, i64) #0 +declare i64 @File.write.236(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.235(ptr, ptr, i64) #0 +declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.236(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.238(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.237(ptr, ptr, ptr) #0 +declare i64 @open_file.239(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.238(ptr, ptr, ptr) #0 +declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.239(ptr, ptr) #0 +declare i1 @write_file.241(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.240(ptr, ptr) #0 +declare i1 @append_file.242(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.241(ptr, ptr) #0 +declare i1 @exists.243(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.242(ptr, ptr) #0 +declare i1 @delete_file.244(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.243(ptr, ptr, i32) #0 +declare i1 @delete_dir.245(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.244(ptr, ptr, ptr) #0 +declare i1 @create_dir.246(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.245(ptr, ptr) #0 +declare i1 @set_mode.247(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.246(ptr, ptr, ptr) #0 +declare i1 @move.248(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.247(ptr, ptr) #0 +declare i1 @create_dir_all.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.248(ptr, ptr) #0 +declare i1 @copy_file.250(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.249(ptr, i32) #0 +declare ptr @basename.251(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.250() #0 +declare ptr @dirname.252(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.251() #0 +declare ptr @spaces.253(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.252(i32) #0 +declare i32 @sx_trace_len.254() #0 ; Function Attrs: nounwind -declare ptr @to_string.253(ptr) #0 +declare i32 @sx_trace_truncated.255() #0 ; Function Attrs: nounwind -declare void @print_current.254(ptr) #0 +declare i64 @sx_trace_frame_at.256(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.255(ptr) #0 +declare ptr @to_string.257(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.256(ptr, ptr) #0 +declare void @print_current.258(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.257(ptr) #0 +declare void @print_interpreter_frames.259(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.258(ptr, i64, i64, ptr) #0 +declare ptr @popen.260(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.259(ptr) #0 +declare i32 @pclose.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.260(ptr) #0 +declare i64 @fread.262(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.261(ptr) #0 +declare i32 @feof.263(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.262(ptr) #0 +declare ptr @getenv.264(ptr) #0 ; Function Attrs: nounwind -declare void @run.263(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.265(ptr) #0 ; Function Attrs: nounwind -declare void @env.264(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.266(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.265(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.266(i32) #0 +declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.267(ptr, i8, ptr) #0 +declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.268(ptr, i1, ptr, ptr) #0 +declare void @_exit.270(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.269(i32, i32, i32) #0 +declare void @exit.271(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.270(i32, i32, i32, ptr, i32) #0 +declare void @assert.272(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.271(i32, ptr, i32) #0 +declare i32 @socket.273(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.272(i32, i32) #0 +declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.273(i32, ptr, ptr) #0 +declare i32 @bind.275(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.274(i32, ptr, i64) #0 +declare i32 @listen.276(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.275(i32) #0 +declare i32 @accept.277(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.276(ptr, i64) #0 +declare i64 @read.278(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.277(ptr, ptr, i64) #0 +declare i32 @close.279(i32) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.278(ptr, ptr, ptr) #0 +declare i16 @htons.280(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.279(ptr) #0 +declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.280(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.281(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.282(ptr, ptr, i64) #0 +declare i64 @GPA.init.284(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.283(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.284(ptr, ptr) #0 +declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.285(ptr, ptr) #0 +declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.286(ptr, ptr, i64) #0 +declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.287(ptr, ptr, ptr) #0 +declare void @Arena.reset.289(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.288(ptr, ptr, i64) #0 +declare void @Arena.deinit.290(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.289(ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.290(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.291(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.init.293(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.292(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.reset.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.293(ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.294(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.297(ptr, i32, ...) #0 +declare void @TrackingAllocator.report.299(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.298(i32) #0 +declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @read.299(i32, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.300(i32, i64, i32) #0 +declare i32 @open.302(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.301(ptr) #0 +declare i32 @close.303(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.302(ptr) #0 +declare i64 @read.304(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.303(ptr, i32) #0 +declare i64 @lseek.305(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.304(ptr, i32) #0 +declare i32 @unlink.306(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.305(ptr, i32) #0 +declare i32 @rmdir.307(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.306(ptr, ptr) #0 +declare i32 @mkdir.308(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.307(ptr, ptr) #0 +declare i32 @access.309(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.308(ptr, ptr) #0 +declare i32 @chmod.310(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.309(ptr, ptr, ptr) #0 +declare i32 @rename.311(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.310(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.312(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.311(ptr, ptr, i64, i64) #0 +declare i1 @File.close.313(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.312(ptr, i64) #0 +declare i64 @File.read.314(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.313(ptr, ptr, i64) #0 +declare i64 @File.write.315(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.314(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.315(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.317(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.316(ptr, ptr, ptr) #0 +declare i64 @open_file.318(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.317(ptr, ptr) #0 +declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.318(ptr, ptr) #0 +declare i1 @write_file.320(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.319(ptr, ptr) #0 +declare i1 @append_file.321(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.320(ptr, ptr) #0 +declare i1 @exists.322(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.321(ptr, ptr, i32) #0 +declare i1 @delete_file.323(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.322(ptr, ptr, ptr) #0 +declare i1 @delete_dir.324(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.323(ptr, ptr) #0 +declare i1 @create_dir.325(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.324(ptr, ptr, ptr) #0 +declare i1 @set_mode.326(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.325(ptr, ptr) #0 +declare i1 @move.327(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.326(ptr, ptr) #0 +declare i1 @create_dir_all.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.327(ptr, ptr, ptr, ptr) #0 +declare i1 @copy_file.329(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.328(ptr, ptr, ptr) #0 +declare ptr @basename.330(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.329(ptr, ptr, ptr, ptr, ptr) #0 +declare ptr @dirname.331(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.330(ptr, ptr, ptr) #0 +declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.331(ptr, ptr, i8) #0 +declare void @Array.deinit.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.332(ptr, ptr, ptr) #0 +declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.333(ptr, ptr) #0 +declare void @Object.deinit.335(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.334(ptr, i64) #0 +declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.335(ptr, i8, ptr) #0 +declare i32 @Sink.put.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.336(ptr, ptr, ptr) #0 +declare i32 @Sink.flush.338(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_int.337(ptr, i64, ptr) #0 +declare i8 @hex_digit.339(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_value.338(ptr, ptr, ptr) #0 +declare i32 @write_u_escape.340(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.339(ptr, ptr, ptr) #0 +declare i32 @write_string.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.340(ptr, ptr, ptr) #0 +declare i32 @write_int.342(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.341(ptr, ptr, ptr) #0 +declare i32 @write_value.343(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.342(ptr, ptr, ptr, ptr) #0 +declare i32 @write_array.344(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.343(ptr, i8) #0 +declare i32 @write_object.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.344(ptr, i64, ptr) #0 +declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.345(ptr, ptr) #0 +declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.346(ptr, ptr, ptr) #0 +declare [2 x i64] @hex_value.348(ptr, i8) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.347(ptr, ptr, i64, i64) #0 +declare i64 @encode_utf8.349(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.348(ptr, ptr, i64, i64, ptr) #0 +declare void @Parser.skip_ws.350(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.349(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.350(ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.351(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.352(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.353(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.354(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.355(i64, ptr) #0 +declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.356(i64, ptr) #0 +declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.357(i64, ptr) #0 +declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.358(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.359(i64, ptr, ptr) #0 +declare void @BuildOptions.add_framework.361(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.360(i64) #0 +declare void @BuildOptions.set_output_path.362(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.361(i64, i64) #0 +declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.362(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.363(i64, ptr) #0 +declare i64 @BuildOptions.asset_dir_count.365(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.364(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.365(i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.366(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.367(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.368(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.370(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.369(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.370(i64) #0 +declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.371(i64) #0 +declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.372(i64) #0 +declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.373(i64) #0 +declare ptr @BuildOptions.bundle_path.375(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.374(i64) #0 +declare ptr @BuildOptions.bundle_id.376(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.375(i64) #0 +declare ptr @BuildOptions.codesign_identity.377(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.376(i64) #0 +declare ptr @BuildOptions.provisioning_profile.378(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.377(i64) #0 +declare ptr @BuildOptions.target_triple.379(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.378(i64) #0 +declare i1 @BuildOptions.is_macos.380(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.379(i64) #0 +declare i1 @BuildOptions.is_ios.381(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.380(i64) #0 +declare i1 @BuildOptions.is_ios_device.382(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.381(i64, i64) #0 +declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.382(i64) #0 +declare i1 @BuildOptions.is_android.384(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.383(i64, i64) #0 +declare i64 @BuildOptions.framework_count.385(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.384(i64, ptr) #0 +declare ptr @BuildOptions.framework_at.386(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.385(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.386(i64) #0 +declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.387(i64) #0 +declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.388(i64) #0 +declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.389(i64, i64) #0 +declare ptr @BuildOptions.manifest_path.391(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.390(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.392(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.391() #0 +declare i64 @BuildOptions.jni_main_count.393(i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.392(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.393() #0 +declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.394() #0 +declare i64 @build_options.396() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.395(i32) #0 +declare ptr @spaces.397(ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.396(ptr) #0 +declare i32 @sx_trace_len.398() #0 ; Function Attrs: nounwind -declare void @print_current.397(ptr) #0 +declare i32 @sx_trace_truncated.399() #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.398(ptr) #0 +declare i64 @sx_trace_frame_at.400(i32) #0 ; Function Attrs: nounwind -declare ptr @popen.399(ptr, ptr) #0 +declare ptr @to_string.401(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.400(ptr) #0 +declare void @print_current.402(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.401(ptr, i64, i64, ptr) #0 +declare void @print_interpreter_frames.403(ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.402(ptr) #0 +declare ptr @popen.404(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.403(ptr) #0 +declare i32 @pclose.405(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.404(ptr) #0 +declare i64 @fread.406(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @system.405(ptr) #0 +declare i32 @feof.407(ptr) #0 ; Function Attrs: nounwind -declare void @run.406(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare ptr @getenv.408(ptr) #0 ; Function Attrs: nounwind -declare void @env.407(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @strlen.409(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.408(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.410(ptr) #0 ; Function Attrs: nounwind -declare void @_exit.409(i32) #0 +declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.410(ptr, i8, ptr) #0 +declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.411(ptr, i1, ptr, ptr) #0 +declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.412() #0 +declare void @_exit.414(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.413() #0 +declare void @exit.415(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.414(ptr) #0 +declare void @assert.416(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_usage.415(ptr) #0 +declare ptr @_NSGetArgv.417() #0 ; Function Attrs: nounwind -declare i64 @os_argc.416(ptr) #0 +declare ptr @_NSGetArgc.418() #0 ; Function Attrs: nounwind -declare ptr @os_args.417(ptr, ptr) #0 +declare void @exit_ok.419(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.418(ptr, ptr, ptr) #0 +declare void @exit_usage.420(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.419(ptr, ptr, ptr) #0 +declare i64 @os_argc.421(ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.420(ptr, ptr) #0 +declare ptr @os_args.422(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.421(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.422(ptr, i32, ...) #0 +declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.423(i32) #0 +declare i1 @is_long_flag.425(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.424(i32, ptr, i64) #0 +declare void @parse.426(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.425(i32, i64, i32) #0 +declare i32 @open.427(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.426(ptr) #0 +declare i32 @close.428(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.427(ptr) #0 +declare i64 @read.429(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.428(ptr, i32) #0 +declare i64 @lseek.430(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.429(ptr, i32) #0 +declare i32 @unlink.431(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.430(ptr, i32) #0 +declare i32 @rmdir.432(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.431(ptr, ptr) #0 +declare i32 @mkdir.433(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.432(ptr, ptr) #0 +declare i32 @access.434(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.433(ptr, ptr) #0 +declare i32 @chmod.435(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.434(ptr, ptr, ptr) #0 +declare i32 @rename.436(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.435(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.437(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.436(ptr, ptr, i64, i64) #0 +declare i1 @File.close.438(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.437(ptr, i64) #0 +declare i64 @File.read.439(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.438(ptr, ptr, i64) #0 +declare i64 @File.write.440(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.439(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.440(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.442(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.441(ptr, ptr, ptr) #0 +declare i64 @open_file.443(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.442(ptr, ptr) #0 +declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.443(ptr, ptr) #0 +declare i1 @write_file.445(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.444(ptr, ptr) #0 +declare i1 @append_file.446(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.445(ptr, ptr) #0 +declare i1 @exists.447(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.446(ptr, ptr, i32) #0 +declare i1 @delete_file.448(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.447(ptr, ptr, ptr) #0 +declare i1 @delete_dir.449(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.448(ptr, ptr) #0 +declare i1 @create_dir.450(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.449(ptr, ptr, ptr) #0 +declare i1 @set_mode.451(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.450(ptr, ptr) #0 +declare i1 @move.452(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.451(ptr, ptr) #0 +declare i1 @create_dir_all.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.452(ptr, i64, i64) #0 +declare i1 @copy_file.454(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.453(ptr, i64) #0 +declare ptr @basename.455(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.454(ptr, i64) #0 +declare ptr @dirname.456(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.455(ptr, i64) #0 +declare i64 @rotr.457(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.456(ptr, i64) #0 +declare i64 @big_sigma0.458(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.457(ptr, ptr) #0 +declare i64 @big_sigma1.459(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.458(ptr, ptr, ptr) #0 +declare i64 @small_sigma0.460(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.459(ptr, ptr) #0 +declare i64 @small_sigma1.461(ptr, i64) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.460(ptr, i64) #0 +declare void @Sha256.process_block.462(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.461(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare void @Sha256.update.463(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.462(ptr, ptr) #0 +declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @sha256_file.463(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare i8 @nibble_hex.465(ptr, i64) #0 ; Function Attrs: nounwind -declare void @assert.464(ptr, i1) #0 +declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 + +; Function Attrs: nounwind +declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.469(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4722,14 +4740,14 @@ entry: define internal void @print__ct_s86e89ca9c0674196__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.672, i64 29 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.677, i64 29 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.673, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.678, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 29) @@ -4745,7 +4763,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.674, i64 29 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.679, i64 29 }) ret { ptr, i64 } %call } @@ -4753,7 +4771,7 @@ entry: define internal void @print__ct_sfd746eca0faee40b__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.675, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.680, i64 11 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4769,7 +4787,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.676, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.681, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -4797,7 +4815,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.677, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.682, i64 11 }) ret { ptr, i64 } %call } @@ -4805,7 +4823,7 @@ entry: define internal void @print__ct_s61f699add92dd2af__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.678, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.683, i64 9 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4821,7 +4839,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.679, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.684, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -4849,7 +4867,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.680, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.685, i64 9 }) ret { ptr, i64 } %call } @@ -4860,7 +4878,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 15 }, { ptr, i64 } { ptr @str.682, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 15 }, { ptr, i64 } { ptr @str.687, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4879,12 +4897,12 @@ while.body.125: ; preds = %while.hdr.124 while.exit.126: ; preds = %while.hdr.124 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) ret { ptr, i64 } %callN if.then.127: ; preds = %while.body.125 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.128 @@ -4896,7 +4914,7 @@ if.merge.128: ; preds = %if.then.127, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4949,20 +4967,20 @@ fv.case24: ; preds = %if.merge.128 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 10 }, { ptr, i64 } { ptr @str.690, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 9 }, { ptr, i64 } { ptr @str.695, 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.129 -while.hdr.129: ; preds = %if.merge.133, %entry +while.hdr.129: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.130, label %while.exit.131 while.body.130: ; preds = %while.hdr.129 @@ -4972,224 +4990,24 @@ while.body.130: ; preds = %while.hdr.129 while.exit.131: ; preds = %while.hdr.129 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 1 }) ret { ptr, i64 } %callN if.then.132: ; preds = %while.body.130 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.133 if.merge.133: ; preds = %if.then.132, %while.body.130 %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.693, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.701, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.129 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } { ptr @str.696, 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.134 - -while.hdr.134: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.135, label %while.exit.136 - -while.body.135: ; preds = %while.hdr.134 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.137, label %if.merge.138 - -while.exit.136: ; preds = %while.hdr.134 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 1 }) - ret { ptr, i64 } %callN - -if.then.137: ; preds = %while.body.135 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.698, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.138 - -if.merge.138: ; preds = %if.then.137, %while.body.135 - %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.700, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.701, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.134 - -fv.default: ; preds = %if.merge.138 - br label %fv.merge - -fv.case: ; preds = %if.merge.138 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 10 }, { ptr, i64 } { ptr @str.703, 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.139 - -while.hdr.139: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.140, label %while.exit.141 - -while.body.140: ; preds = %while.hdr.139 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.142, label %if.merge.143 - -while.exit.141: ; preds = %while.hdr.139 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.704, i64 1 }) - ret { ptr, i64 } %callN - -if.then.142: ; preds = %while.body.140 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.143 - -if.merge.143: ; preds = %if.then.142, %while.body.140 - %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.708, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.139 - -fv.default: ; preds = %if.merge.143 - br label %fv.merge - -fv.case: ; preds = %if.merge.143 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.143 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 9 }, { ptr, i64 } { ptr @str.711, 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.144 - -while.hdr.144: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.145, label %while.exit.146 - -while.body.145: ; preds = %while.hdr.144 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.147, label %if.merge.148 - -while.exit.146: ; preds = %while.hdr.144 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 1 }) - ret { ptr, i64 } %callN - -if.then.147: ; preds = %while.body.145 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.148 - -if.merge.148: ; preds = %if.then.147, %while.body.145 - %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.717, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.718, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.702, 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 @@ -5208,27 +5026,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.129 + +fv.default: ; preds = %if.merge.133 + br label %fv.merge + +fv.case: ; preds = %if.merge.133 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.133 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.133 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 10 }, { ptr, i64 } { ptr @str.704, 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.134 + +while.hdr.134: ; preds = %if.merge.138, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.135, label %while.exit.136 + +while.body.135: ; preds = %while.hdr.134 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.137, label %if.merge.138 + +while.exit.136: ; preds = %while.hdr.134 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 1 }) + ret { ptr, i64 } %callN + +if.then.137: ; preds = %while.body.135 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.138 + +if.merge.138: ; preds = %if.then.137, %while.body.135 + %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.707, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.708, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.134 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } { ptr @str.710, 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.139 + +while.hdr.139: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.140, label %while.exit.141 + +while.body.140: ; preds = %while.hdr.139 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.142, label %if.merge.143 + +while.exit.141: ; preds = %while.hdr.139 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.711, i64 1 }) + ret { ptr, i64 } %callN + +if.then.142: ; preds = %while.body.140 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.143 + +if.merge.143: ; preds = %if.then.142, %while.body.140 + %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.714, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.715, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.139 + +fv.default: ; preds = %if.merge.143 + br label %fv.merge + +fv.case: ; preds = %if.merge.143 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 10 }, { ptr, i64 } { ptr @str.717, 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.144 + +while.hdr.144: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.145, label %while.exit.146 + +while.body.145: ; preds = %while.hdr.144 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.147, label %if.merge.148 + +while.exit.146: ; preds = %while.hdr.144 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.718, i64 1 }) + ret { ptr, i64 } %callN + +if.then.147: ; preds = %while.body.145 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.148 + +if.merge.148: ; preds = %if.then.147, %while.body.145 + %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.722, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.144 fv.default: ; preds = %if.merge.148 br label %fv.merge fv.case: ; preds = %if.merge.148 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.148 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.148 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -5238,7 +5256,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 5 }, { ptr, i64 } { ptr @str.720, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 5 }, { ptr, i64 } { ptr @str.725, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5257,24 +5275,24 @@ while.body.150: ; preds = %while.hdr.149 while.exit.151: ; preds = %while.hdr.149 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.721, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.726, i64 1 }) ret { ptr, i64 } %callN if.then.152: ; preds = %while.body.150 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.722, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.153 if.merge.153: ; preds = %if.then.152, %while.body.150 %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.726, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.731, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.732, 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 @@ -5301,7 +5319,7 @@ fv.default: ; preds = %if.merge.153 fv.case: ; preds = %if.merge.153 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.153 @@ -5313,7 +5331,7 @@ fv.case20: ; preds = %if.merge.153 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -5322,7 +5340,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 8 }, { ptr, i64 } { ptr @str.729, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 8 }, { ptr, i64 } { ptr @str.734, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5341,24 +5359,24 @@ while.body.155: ; preds = %while.hdr.154 while.exit.156: ; preds = %while.hdr.154 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.730, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.735, i64 1 }) ret { ptr, i64 } %callN if.then.157: ; preds = %while.body.155 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.158 if.merge.158: ; preds = %if.then.157, %while.body.155 %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.735, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.740, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.741, 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 @@ -5405,7 +5423,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 17 }, { ptr, i64 } { ptr @str.738, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 17 }, { ptr, i64 } { ptr @str.743, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5424,24 +5442,24 @@ while.body.160: ; preds = %while.hdr.159 while.exit.161: ; preds = %while.hdr.159 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.739, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.744, i64 1 }) ret { ptr, i64 } %callN if.then.162: ; preds = %while.body.160 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.745, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.163 if.merge.163: ; preds = %if.then.162, %while.body.160 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.745, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.750, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.746, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.751, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5470,7 +5488,7 @@ fv.case: ; preds = %if.merge.163 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.163 @@ -5495,7 +5513,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 7 }, { ptr, i64 } { ptr @str.748, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 7 }, { ptr, i64 } { ptr @str.753, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5514,24 +5532,24 @@ while.body.165: ; preds = %while.hdr.164 while.exit.166: ; preds = %while.hdr.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.749, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.754, i64 1 }) ret { ptr, i64 } %callN if.then.167: ; preds = %while.body.165 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.750, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.755, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.168 if.merge.168: ; preds = %if.then.167, %while.body.165 %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.753, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.758, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.754, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.759, 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 @@ -5558,7 +5576,7 @@ fv.case: ; preds = %if.merge.168 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.168 @@ -5573,7 +5591,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 4 }, { ptr, i64 } { ptr @str.756, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 4 }, { ptr, i64 } { ptr @str.761, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5592,24 +5610,24 @@ while.body.170: ; preds = %while.hdr.169 while.exit.171: ; preds = %while.hdr.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.757, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.762, i64 1 }) ret { ptr, i64 } %callN if.then.172: ; preds = %while.body.170 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.758, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.763, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.173 if.merge.173: ; preds = %if.then.172, %while.body.170 %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.760, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.765, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.761, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.766, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -5646,7 +5664,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 10 }, { ptr, i64 } { ptr @str.763, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 10 }, { ptr, i64 } { ptr @str.768, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5665,24 +5683,24 @@ while.body.175: ; preds = %while.hdr.174 while.exit.176: ; preds = %while.hdr.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.764, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.769, i64 1 }) ret { ptr, i64 } %callN if.then.177: ; preds = %while.body.175 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.765, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.770, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.178 if.merge.178: ; preds = %if.then.177, %while.body.175 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.771, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.776, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.772, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.777, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5748,7 +5766,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 13 }, { ptr, i64 } { ptr @str.774, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 13 }, { ptr, i64 } { ptr @str.779, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5767,24 +5785,24 @@ while.body.180: ; preds = %while.hdr.179 while.exit.181: ; preds = %while.hdr.179 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.775, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.780, i64 1 }) ret { ptr, i64 } %callN if.then.182: ; preds = %while.body.180 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.776, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.781, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.183 if.merge.183: ; preds = %if.then.182, %while.body.180 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.779, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.784, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.780, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.785, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5826,7 +5844,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 8 }, { ptr, i64 } { ptr @str.782, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 8 }, { ptr, i64 } { ptr @str.787, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5845,24 +5863,24 @@ while.body.185: ; preds = %while.hdr.184 while.exit.186: ; preds = %while.hdr.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.783, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.788, i64 1 }) ret { ptr, i64 } %callN if.then.187: ; preds = %while.body.185 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.784, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.789, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.188 if.merge.188: ; preds = %if.then.187, %while.body.185 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.790, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.795, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.791, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.796, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5923,7 +5941,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 5 }, { ptr, i64 } { ptr @str.793, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 5 }, { ptr, i64 } { ptr @str.798, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5942,24 +5960,24 @@ while.body.190: ; preds = %while.hdr.189 while.exit.191: ; preds = %while.hdr.189 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.794, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.799, i64 1 }) ret { ptr, i64 } %callN if.then.192: ; preds = %while.body.190 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.795, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.800, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.193 if.merge.193: ; preds = %if.then.192, %while.body.190 %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.799, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.804, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.800, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.805, 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 @@ -6005,7 +6023,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 6 }, { ptr, i64 } { ptr @str.802, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 6 }, { ptr, i64 } { ptr @str.807, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6024,24 +6042,24 @@ while.body.195: ; preds = %while.hdr.194 while.exit.196: ; preds = %while.hdr.194 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.803, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.808, i64 1 }) ret { ptr, i64 } %callN if.then.197: ; preds = %while.body.195 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.804, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.809, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.198 if.merge.198: ; preds = %if.then.197, %while.body.195 %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.808, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.813, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.809, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.814, 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 @@ -6089,7 +6107,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 6 }, { ptr, i64 } { ptr @str.811, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.815, i64 6 }, { ptr, i64 } { ptr @str.816, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6108,24 +6126,24 @@ while.body.200: ; preds = %while.hdr.199 while.exit.201: ; preds = %while.hdr.199 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.812, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.817, i64 1 }) ret { ptr, i64 } %callN if.then.202: ; preds = %while.body.200 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.813, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.818, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.203 if.merge.203: ; preds = %if.then.202, %while.body.200 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.816, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.821, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.817, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.822, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -6169,7 +6187,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.818, i64 4 }, { ptr, i64 } { ptr @str.819, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.823, i64 4 }, { ptr, i64 } { ptr @str.824, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6188,24 +6206,24 @@ while.body.205: ; preds = %while.hdr.204 while.exit.206: ; preds = %while.hdr.204 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.820, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.825, i64 1 }) ret { ptr, i64 } %callN if.then.207: ; preds = %while.body.205 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.821, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.826, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.208 if.merge.208: ; preds = %if.then.207, %while.body.205 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.825, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.830, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.826, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.831, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -6255,7 +6273,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.827, i64 6 }, { ptr, i64 } { ptr @str.828, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.832, i64 6 }, { ptr, i64 } { ptr @str.833, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6274,24 +6292,24 @@ while.body.210: ; preds = %while.hdr.209 while.exit.211: ; preds = %while.hdr.209 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.829, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.834, i64 1 }) ret { ptr, i64 } %callN if.then.212: ; preds = %while.body.210 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.830, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.835, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.213 if.merge.213: ; preds = %if.then.212, %while.body.210 %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.834, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.839, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.835, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.840, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -6331,7 +6349,7 @@ fv.case20: ; preds = %if.merge.213 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -6340,7 +6358,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.836, i64 12 }, { ptr, i64 } { ptr @str.837, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.841, i64 12 }, { ptr, i64 } { ptr @str.842, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6359,24 +6377,24 @@ while.body.215: ; preds = %while.hdr.214 while.exit.216: ; preds = %while.hdr.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.838, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.843, i64 1 }) ret { ptr, i64 } %callN if.then.217: ; preds = %while.body.215 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.839, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.844, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.218 if.merge.218: ; preds = %if.then.217, %while.body.215 %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.840, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.845, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.841, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.846, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6396,7 +6414,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.842, i64 8 }, { ptr, i64 } { ptr @str.843, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.847, i64 8 }, { ptr, i64 } { ptr @str.848, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6415,24 +6433,24 @@ while.body.220: ; preds = %while.hdr.219 while.exit.221: ; preds = %while.hdr.219 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.844, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.849, i64 1 }) ret { ptr, i64 } %callN if.then.222: ; preds = %while.body.220 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.845, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.850, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.223 if.merge.223: ; preds = %if.then.222, %while.body.220 %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.849, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.854, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.850, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.855, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -6484,7 +6502,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.851, i64 7 }, { ptr, i64 } { ptr @str.852, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.856, i64 7 }, { ptr, i64 } { ptr @str.857, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6503,24 +6521,24 @@ while.body.225: ; preds = %while.hdr.224 while.exit.226: ; preds = %while.hdr.224 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.853, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.858, i64 1 }) ret { ptr, i64 } %callN if.then.227: ; preds = %while.body.225 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.854, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.859, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.228 if.merge.228: ; preds = %if.then.227, %while.body.225 %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.858, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.863, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.859, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.864, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6572,7 +6590,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.860, i64 9 }, { ptr, i64 } { ptr @str.861, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.865, i64 9 }, { ptr, i64 } { ptr @str.866, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6591,24 +6609,24 @@ while.body.230: ; preds = %while.hdr.229 while.exit.231: ; preds = %while.hdr.229 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.862, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.867, i64 1 }) ret { ptr, i64 } %callN if.then.232: ; preds = %while.body.230 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.863, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.868, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.233 if.merge.233: ; preds = %if.then.232, %while.body.230 %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.866, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.871, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.867, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.872, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6651,7 +6669,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.868, i64 4 }, { ptr, i64 } { ptr @str.869, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.873, i64 4 }, { ptr, i64 } { ptr @str.874, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6670,24 +6688,24 @@ while.body.235: ; preds = %while.hdr.234 while.exit.236: ; preds = %while.hdr.234 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.870, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 1 }) ret { ptr, i64 } %callN if.then.237: ; preds = %while.body.235 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.871, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.876, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.238 if.merge.238: ; preds = %if.then.237, %while.body.235 %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.874, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.879, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.880, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6733,7 +6751,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.876, i64 6 }, { ptr, i64 } { ptr @str.877, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.881, i64 6 }, { ptr, i64 } { ptr @str.882, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6752,24 +6770,24 @@ while.body.240: ; preds = %while.hdr.239 while.exit.241: ; preds = %while.hdr.239 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.878, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.883, i64 1 }) ret { ptr, i64 } %callN if.then.242: ; preds = %while.body.240 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.879, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.884, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.243 if.merge.243: ; preds = %if.then.242, %while.body.240 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.887, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.892, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.888, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.893, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -6851,7 +6869,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.889, i64 6 }, { ptr, i64 } { ptr @str.890, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.894, i64 6 }, { ptr, i64 } { ptr @str.895, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6870,24 +6888,24 @@ while.body.245: ; preds = %while.hdr.244 while.exit.246: ; preds = %while.hdr.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.891, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.896, i64 1 }) ret { ptr, i64 } %callN if.then.247: ; preds = %while.body.245 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.892, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.897, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.248 if.merge.248: ; preds = %if.then.247, %while.body.245 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.897, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.902, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.898, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.903, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6943,7 +6961,7 @@ entry: %alloca = alloca { [16 x float] }, align 8 %ba.tmp = alloca [16 x float], align 4 store { [16 x float] } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.899, i64 4 }, { ptr, i64 } { ptr @str.900, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.904, i64 4 }, { ptr, i64 } { ptr @str.905, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6962,24 +6980,24 @@ while.body.250: ; preds = %while.hdr.249 while.exit.251: ; preds = %while.hdr.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.901, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.906, i64 1 }) ret { ptr, i64 } %callN if.then.252: ; preds = %while.body.250 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.902, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.907, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.253 if.merge.253: ; preds = %if.then.252, %while.body.250 %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.904, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.909, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.905, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.910, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -7014,7 +7032,7 @@ define internal { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %1 entry: %alloca = alloca { float, float }, align 8 store { float, float } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.906, i64 4 }, { ptr, i64 } { ptr @str.907, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.911, i64 4 }, { ptr, i64 } { ptr @str.912, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7033,24 +7051,24 @@ while.body.255: ; preds = %while.hdr.254 while.exit.256: ; preds = %while.hdr.254 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.908, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.913, i64 1 }) ret { ptr, i64 } %callN if.then.257: ; preds = %while.body.255 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.909, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.914, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 if.merge.258: ; preds = %if.then.257, %while.body.255 %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.912, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.917, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.913, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7093,7 +7111,7 @@ define internal { ptr, i64 } @struct_to_string__Point(ptr %0, { i32, i32 } %1) # entry: %alloca = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.914, i64 5 }, { ptr, i64 } { ptr @str.915, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.919, i64 5 }, { ptr, i64 } { ptr @str.920, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7112,24 +7130,24 @@ while.body.260: ; preds = %while.hdr.259 while.exit.261: ; preds = %while.hdr.259 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.916, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.921, i64 1 }) ret { ptr, i64 } %callN if.then.262: ; preds = %while.body.260 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.917, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.922, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.263 if.merge.263: ; preds = %if.then.262, %while.body.260 %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.920, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.925, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.921, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.926, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7174,9 +7192,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.927, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.932, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.922, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.927, 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 @@ -7195,8 +7213,8 @@ entry: if.then.271: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.929, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.928, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.934, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.933, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 @@ -7215,9 +7233,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.934, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.939, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.930, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.935, 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 @@ -7236,8 +7254,8 @@ entry: if.then.273: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.936, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.935, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.941, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.940, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.274 @@ -7267,9 +7285,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.944, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.949, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.937, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.942, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -7286,8 +7304,8 @@ entry: if.then.275: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.946, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.945, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.951, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.950, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 @@ -7365,9 +7383,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.955, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.960, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.947, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.952, 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 @@ -7386,8 +7404,8 @@ entry: if.then.277: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.957, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.956, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.962, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.961, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.278 @@ -7406,9 +7424,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.964, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.969, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.958, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.963, 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 @@ -7427,8 +7445,8 @@ entry: if.then.279: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.966, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.965, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.971, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.970, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -7445,7 +7463,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.967, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.972, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.290 @@ -7462,12 +7480,12 @@ while.body.291: ; preds = %while.hdr.290 while.exit.292: ; preds = %while.hdr.290 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.968, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.973, i64 1 }) ret { ptr, i64 } %call if.then.293: ; preds = %while.body.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.969, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.974, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.294 @@ -7496,7 +7514,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.970, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.975, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.295 @@ -7513,12 +7531,12 @@ while.body.296: ; preds = %while.hdr.295 while.exit.297: ; preds = %while.hdr.295 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.971, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.976, i64 1 }) ret { ptr, i64 } %call if.then.298: ; preds = %while.body.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.972, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.977, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.299 @@ -7548,7 +7566,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.973, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.978, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.300 @@ -7565,12 +7583,12 @@ while.body.301: ; preds = %while.hdr.300 while.exit.302: ; preds = %while.hdr.300 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.974, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.979, i64 1 }) ret { ptr, i64 } %call if.then.303: ; preds = %while.body.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.975, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.980, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.304 @@ -7598,7 +7616,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.976, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.981, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.305 @@ -7615,12 +7633,12 @@ while.body.306: ; preds = %while.hdr.305 while.exit.307: ; preds = %while.hdr.305 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.977, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.982, i64 1 }) ret { ptr, i64 } %call if.then.308: ; preds = %while.body.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.978, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.983, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.309 @@ -7649,7 +7667,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.979, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.984, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.310 @@ -7666,12 +7684,12 @@ while.body.311: ; preds = %while.hdr.310 while.exit.312: ; preds = %while.hdr.310 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.980, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.985, i64 1 }) ret { ptr, i64 } %call if.then.313: ; preds = %while.body.311 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.981, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.986, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.314 @@ -7699,7 +7717,7 @@ entry: %ig.tmp = alloca [16 x float], align 4 store [16 x float] %1, ptr %alloca, align 4 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.982, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.987, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.315 @@ -7716,12 +7734,12 @@ while.body.316: ; preds = %while.hdr.315 while.exit.317: ; preds = %while.hdr.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.983, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.988, i64 1 }) ret { ptr, i64 } %call if.then.318: ; preds = %while.body.316 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.984, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.989, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.319 @@ -7752,7 +7770,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.985, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.990, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7769,12 +7787,12 @@ while.body.321: ; preds = %while.hdr.320 while.exit.322: ; preds = %while.hdr.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.986, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.991, i64 1 }) ret { ptr, i64 } %call if.then.323: ; preds = %while.body.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.987, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.992, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7804,7 +7822,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.988, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.993, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -7823,12 +7841,12 @@ while.body.333: ; preds = %while.hdr.332 while.exit.334: ; preds = %while.hdr.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.989, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.994, i64 1 }) ret { ptr, i64 } %call if.then.335: ; preds = %while.body.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.990, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.336 @@ -7857,7 +7875,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.991, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.996, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.337 @@ -7876,12 +7894,12 @@ while.body.338: ; preds = %while.hdr.337 while.exit.339: ; preds = %while.hdr.337 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.992, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.997, i64 1 }) ret { ptr, i64 } %call if.then.340: ; preds = %while.body.338 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.993, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.998, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.341 @@ -7910,7 +7928,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.994, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.999, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.342 @@ -7929,12 +7947,12 @@ while.body.343: ; preds = %while.hdr.342 while.exit.344: ; preds = %while.hdr.342 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1000, i64 1 }) ret { ptr, i64 } %call if.then.345: ; preds = %while.body.343 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.996, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1001, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.346 @@ -7964,7 +7982,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.997, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1002, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -7983,12 +8001,12 @@ while.body.348: ; preds = %while.hdr.347 while.exit.349: ; preds = %while.hdr.347 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.998, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1003, i64 1 }) ret { ptr, i64 } %call if.then.350: ; preds = %while.body.348 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.999, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1004, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.351 @@ -8018,7 +8036,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1000, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1005, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8037,12 +8055,12 @@ while.body.353: ; preds = %while.hdr.352 while.exit.354: ; preds = %while.hdr.352 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1001, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1006, i64 1 }) ret { ptr, i64 } %call if.then.355: ; preds = %while.body.353 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1002, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1007, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.356 @@ -8084,12 +8102,12 @@ if.then.390: ; preds = %entry if.else.391: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1005, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1004, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1010, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1009, i64 5 }, { ptr, i64 } %callN) br label %if.merge.392 if.merge.392: ; preds = %if.else.391, %if.then.390 - %bp = phi { ptr, i64 } [ { ptr @str.1003, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.1008, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -8112,12 +8130,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1008, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1007, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1013, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1012, i64 11 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.1006, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.1011, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -8140,12 +8158,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1011, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1010, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1016, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1015, i64 4 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.1009, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.1014, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -8168,12 +8186,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1014, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1013, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1019, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1018, i64 11 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.1012, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.1017, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -8196,12 +8214,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1017, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1016, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1022, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1021, i64 6 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.1015, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.1020, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -8223,12 +8241,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1020, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1019, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1025, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1024, i64 5 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.1018, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.1023, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -8251,12 +8269,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1023, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1022, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1028, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1027, i64 9 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.1021, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.1026, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -8279,12 +8297,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1026, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1025, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1031, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1030, i64 18 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.1024, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.1029, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -8307,12 +8325,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1029, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1028, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1034, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1033, i64 5 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.1027, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.1032, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -8335,12 +8353,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1032, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1031, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1037, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1036, i64 3 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.1030, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.1035, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -8363,12 +8381,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1035, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1034, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1040, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1039, i64 4 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.1033, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.1038, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -8391,12 +8409,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1038, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1037, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1043, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1042, i64 9 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.1036, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.1041, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -8419,12 +8437,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1041, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1040, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1046, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1045, i64 4 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.1039, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.1044, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -8446,12 +8464,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1044, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1043, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1049, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1048, i64 8 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.1042, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.1047, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -8474,12 +8492,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1047, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1046, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1052, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1051, i64 6 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.1045, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.1050, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -8501,12 +8519,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1050, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1049, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1055, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1054, i64 9 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.1048, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.1053, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -8529,12 +8547,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1053, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1052, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1058, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1057, i64 7 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.1051, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.1056, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -8557,12 +8575,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1056, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1055, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1061, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1060, i64 5 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.1054, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.1059, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -8585,12 +8603,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1059, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1058, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1064, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1063, i64 7 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.1057, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.1062, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -8613,12 +8631,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1062, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1061, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1067, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1066, i64 4 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.1060, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.1065, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -8641,12 +8659,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1065, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1064, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1070, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1069, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.1063, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.1068, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -8669,12 +8687,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1068, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1067, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1073, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1072, i64 5 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.1066, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.1071, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -8697,12 +8715,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1071, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1070, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1076, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1075, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.1069, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.1074, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -8725,12 +8743,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1074, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1073, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1079, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1078, i64 12 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.1072, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.1077, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -8753,12 +8771,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1077, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1076, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1082, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1081, i64 6 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.1075, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.1080, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -8781,12 +8799,12 @@ if.then.478: ; preds = %entry if.else.479: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1080, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1079, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1085, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1084, i64 7 }, { ptr, i64 } %callN) br label %if.merge.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.1078, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.1083, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -8809,12 +8827,12 @@ if.then.481: ; preds = %entry if.else.482: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1083, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1082, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1088, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1087, i64 4 }, { ptr, i64 } %callN) br label %if.merge.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.1081, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.1086, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -8837,12 +8855,12 @@ if.then.484: ; preds = %entry if.else.485: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1086, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1085, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1091, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1090, i64 6 }, { ptr, i64 } %callN) br label %if.merge.486 if.merge.486: ; preds = %if.else.485, %if.then.484 - %bp = phi { ptr, i64 } [ { ptr @str.1084, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.1089, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -8865,12 +8883,12 @@ if.then.487: ; preds = %entry if.else.488: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1089, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1088, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1094, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1093, i64 5 }, { ptr, i64 } %callN) br label %if.merge.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.1087, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.1092, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -8893,12 +8911,12 @@ if.then.490: ; preds = %entry if.else.491: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1092, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1091, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1097, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1096, i64 6 }, { ptr, i64 } %callN) br label %if.merge.492 if.merge.492: ; preds = %if.else.491, %if.then.490 - %bp = phi { ptr, i64 } [ { ptr @str.1090, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.1095, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -8921,12 +8939,12 @@ if.then.493: ; preds = %entry if.else.494: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1095, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1094, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1100, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1099, i64 7 }, { ptr, i64 } %callN) br label %if.merge.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.1093, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.1098, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -8942,7 +8960,7 @@ entry: br i1 %lnot, label %if.then.502, label %if.merge.503 if.then.502: ; preds = %entry - ret { ptr, i64 } { ptr @str.1096, i64 4 } + ret { ptr, i64 } { ptr @str.1101, i64 4 } if.merge.503: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8966,7 +8984,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.1097, i64 4 } + ret { ptr, i64 } { ptr @str.1102, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8990,7 +9008,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.1098, i64 4 } + ret { ptr, i64 } { ptr @str.1103, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9014,7 +9032,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.1099, i64 4 } + ret { ptr, i64 } { ptr @str.1104, i64 4 } if.merge.509: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0044-basic-default-arg-expansion.ir b/examples/expected/0044-basic-default-arg-expansion.ir index 0c472c7..5574447 100644 --- a/examples/expected/0044-basic-default-arg-expansion.ir +++ b/examples/expected/0044-basic-default-arg-expansion.ir @@ -1,625 +1,625 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [162 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [8 x i8] c"*string\00" -@tn.str.239 = private constant [6 x i8] c"[]Any\00" -@tn.str.240 = private constant [5 x i8] c"*Any\00" -@tn.str.241 = private constant [7 x i8] c"[1]Any\00" -@tn.str.242 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.243 = private constant [7 x i8] c"*[]Any\00" -@tn.str.244 = private constant [6 x i8] c"*bool\00" -@tn.str.245 = private constant [7 x i8] c"[3]Any\00" -@tn.str.246 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.247 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.248 = private constant [5 x i8] c"*f64\00" -@tn.str.249 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.250 = private constant [11 x i8] c"*Allocator\00" -@tn.str.251 = private constant [9 x i8] c"*Context\00" -@tn.str.252 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.253 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.254 = private constant [8 x i8] c"*Member\00" -@tn.str.255 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.256 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.257 = private constant [9 x i8] c"*Command\00" -@tn.str.258 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.259 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.260 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.261 = private constant [7 x i8] c"*Value\00" -@tn.str.262 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.263 = private constant [14 x i8] c"*Architecture\00" -@tn.str.264 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.265 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.266 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.267 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.268 = private constant [10 x i8] c"*[]string\00" -@tn.str.269 = private constant [6 x i8] c"*[]u8\00" -@tn.str.270 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.271 = private constant [11 x i8] c"*[]Command\00" -@tn.str.272 = private constant [6 x i8] c"**GPA\00" -@tn.str.273 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.274 = private constant [8 x i8] c"**Arena\00" -@tn.str.275 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.276 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.277 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.278 = private constant [7 x i8] c"**File\00" -@tn.str.279 = private constant [5 x i8] c"**u8\00" -@tn.str.280 = private constant [6 x i8] c"**s32\00" -@tn.str.281 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.282 = private constant [6 x i8] c"**u32\00" -@tn.str.283 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.284 = private constant [8 x i8] c"**Array\00" -@tn.str.285 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.286 = private constant [9 x i8] c"**Object\00" -@tn.str.287 = private constant [7 x i8] c"**Sink\00" -@tn.str.288 = private constant [9 x i8] c"**Parser\00" -@tn.str.289 = private constant [6 x i8] c"**s64\00" -@tn.str.290 = private constant [9 x i8] c"**Parsed\00" -@tn.str.291 = private constant [7 x i8] c"**Diag\00" -@tn.str.292 = private constant [9 x i8] c"**Sha256\00" -@tn.str.293 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.294 = private constant [8 x i8] c"***void\00" -@tn.str.295 = private constant [9 x i8] c"**string\00" -@tn.str.296 = private constant [6 x i8] c"**Any\00" -@tn.str.297 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.298 = private constant [8 x i8] c"**[]Any\00" -@tn.str.299 = private constant [7 x i8] c"**bool\00" -@tn.str.300 = private constant [9 x i8] c"**[3]Any\00" -@tn.str.301 = private constant [7 x i8] c"*?File\00" -@tn.str.302 = private constant [9 x i8] c"*?string\00" -@tn.str.303 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.304 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 5 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 5 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 16 }, { ptr, i64 } { ptr @tn.str.250, i64 10 }, { ptr, i64 } { ptr @tn.str.251, i64 8 }, { ptr, i64 } { ptr @tn.str.252, i64 11 }, { ptr, i64 } { ptr @tn.str.253, i64 14 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 13 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 6 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 5 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 12 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 19 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 4 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 10 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 13 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 15 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }] -@str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [8 x i8] c"*string\00" +@tn.str.241 = private constant [6 x i8] c"[]Any\00" +@tn.str.242 = private constant [5 x i8] c"*Any\00" +@tn.str.243 = private constant [7 x i8] c"[1]Any\00" +@tn.str.244 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.245 = private constant [7 x i8] c"*[]Any\00" +@tn.str.246 = private constant [6 x i8] c"*bool\00" +@tn.str.247 = private constant [7 x i8] c"[3]Any\00" +@tn.str.248 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.250 = private constant [5 x i8] c"*f64\00" +@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.252 = private constant [11 x i8] c"*Allocator\00" +@tn.str.253 = private constant [9 x i8] c"*Context\00" +@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.256 = private constant [8 x i8] c"*Member\00" +@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.259 = private constant [9 x i8] c"*Command\00" +@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.263 = private constant [7 x i8] c"*Value\00" +@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.265 = private constant [14 x i8] c"*Architecture\00" +@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.270 = private constant [10 x i8] c"*[]string\00" +@tn.str.271 = private constant [6 x i8] c"*[]u8\00" +@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.273 = private constant [11 x i8] c"*[]Command\00" +@tn.str.274 = private constant [6 x i8] c"**GPA\00" +@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.276 = private constant [8 x i8] c"**Arena\00" +@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.280 = private constant [7 x i8] c"**File\00" +@tn.str.281 = private constant [5 x i8] c"**u8\00" +@tn.str.282 = private constant [6 x i8] c"**s32\00" +@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.284 = private constant [6 x i8] c"**u32\00" +@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.286 = private constant [8 x i8] c"**Array\00" +@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.288 = private constant [9 x i8] c"**Object\00" +@tn.str.289 = private constant [7 x i8] c"**Sink\00" +@tn.str.290 = private constant [9 x i8] c"**Parser\00" +@tn.str.291 = private constant [6 x i8] c"**s64\00" +@tn.str.292 = private constant [9 x i8] c"**Parsed\00" +@tn.str.293 = private constant [7 x i8] c"**Diag\00" +@tn.str.294 = private constant [9 x i8] c"**Sha256\00" +@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.296 = private constant [8 x i8] c"***void\00" +@tn.str.297 = private constant [9 x i8] c"**string\00" +@tn.str.298 = private constant [6 x i8] c"**Any\00" +@tn.str.299 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.300 = private constant [8 x i8] c"**[]Any\00" +@tn.str.301 = private constant [7 x i8] c"**bool\00" +@tn.str.302 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.303 = private constant [7 x i8] c"*?File\00" +@tn.str.304 = private constant [9 x i8] c"*?string\00" +@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 5 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }] @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.311 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.312 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.313 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.314 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.315 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.316 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.326 = private unnamed_addr constant [2 x i8] c"v\00", align 1 -@str.327 = private unnamed_addr constant [2 x i8] c"!\00", align 1 -@str.328 = private unnamed_addr constant [2 x i8] c"x\00", align 1 +@str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.313 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.314 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.315 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.316 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.317 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.318 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.328 = private unnamed_addr constant [2 x i8] c"v\00", align 1 @str.329 = private unnamed_addr constant [2 x i8] c"!\00", align 1 -@str.330 = private unnamed_addr constant [2 x i8] c"y\00", align 1 -@str.331 = private unnamed_addr constant [2 x i8] c"?\00", align 1 -@str.332 = private unnamed_addr constant [13 x i8] c"default: {}\0A\00", align 1 -@str.333 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [2 x i8] c"x\00", align 1 +@str.331 = private unnamed_addr constant [2 x i8] c"!\00", align 1 +@str.332 = private unnamed_addr constant [2 x i8] c"y\00", align 1 +@str.333 = private unnamed_addr constant [2 x i8] c"?\00", align 1 @str.334 = private unnamed_addr constant [13 x i8] c"default: {}\0A\00", align 1 -@str.335 = private unnamed_addr constant [14 x i8] c"explicit: {}\0A\00", align 1 -@str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.335 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.336 = private unnamed_addr constant [13 x i8] c"default: {}\0A\00", align 1 @str.337 = private unnamed_addr constant [14 x i8] c"explicit: {}\0A\00", align 1 -@str.338 = private unnamed_addr constant [8 x i8] c"{}{}{}\0A\00", align 1 -@str.339 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.338 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [14 x i8] c"explicit: {}\0A\00", align 1 @str.340 = private unnamed_addr constant [8 x i8] c"{}{}{}\0A\00", align 1 -@str.341 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.342 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.343 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.344 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.341 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.342 = private unnamed_addr constant [8 x i8] c"{}{}{}\0A\00", align 1 +@str.343 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.345 = private constant [5 x i8] c"line\00" -@fld.str.346 = private constant [4 x i8] c"col\00" -@fld.str.347 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.345, i64 4 }, { ptr, i64 } { ptr @fld.str.346, i64 3 }, { ptr, i64 } { ptr @fld.str.347, i64 4 }] -@str.348 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.349 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.350 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.352 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.353 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.355 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.359 = private constant [12 x i8] c"alloc_count\00" -@field_names.360 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 11 }] -@str.361 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.362 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.363 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.364 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.366 = private constant [5 x i8] c"next\00" -@fld.str.367 = private constant [4 x i8] c"cap\00" -@field_names.368 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.366, i64 4 }, { ptr, i64 } { ptr @fld.str.367, i64 3 }] -@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.370 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.371 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.372 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.374 = private constant [4 x i8] c"ctx\00" -@fld.str.375 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.376 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.377 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 3 }, { ptr, i64 } { ptr @fld.str.375, i64 11 }, { ptr, i64 } { ptr @fld.str.376, i64 13 }] -@str.378 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.379 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.380 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.381 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.382 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.383 = private constant [6 x i8] c"first\00" -@fld.str.384 = private constant [10 x i8] c"end_index\00" -@fld.str.385 = private constant [7 x i8] c"parent\00" -@field_names.386 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.383, i64 5 }, { ptr, i64 } { ptr @fld.str.384, i64 9 }, { ptr, i64 } { ptr @fld.str.385, i64 6 }] -@str.387 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.388 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.389 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.390 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.391 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.392 = private constant [4 x i8] c"buf\00" -@fld.str.393 = private constant [4 x i8] c"len\00" -@fld.str.394 = private constant [4 x i8] c"pos\00" -@field_names.395 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.392, i64 3 }, { ptr, i64 } { ptr @fld.str.393, i64 3 }, { ptr, i64 } { ptr @fld.str.394, i64 3 }] -@str.396 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.397 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.398 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.399 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.400 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.401 = private constant [7 x i8] c"parent\00" -@fld.str.402 = private constant [12 x i8] c"alloc_count\00" -@fld.str.403 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.404 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.405 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.401, i64 6 }, { ptr, i64 } { ptr @fld.str.402, i64 11 }, { ptr, i64 } { ptr @fld.str.403, i64 13 }, { ptr, i64 } { ptr @fld.str.404, i64 17 }] -@str.406 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.407 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.408 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.409 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.410 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.411 = private constant [10 x i8] c"allocator\00" -@fld.str.412 = private constant [5 x i8] c"data\00" -@field_names.413 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.411, i64 9 }, { ptr, i64 } { ptr @fld.str.412, i64 4 }] -@str.414 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.415 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.416 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.417 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.418 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.419 = private constant [3 x i8] c"fd\00" -@field_names.420 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.419, i64 2 }] -@str.421 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.422 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.423 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.424 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.425 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.426 = private constant [5 x i8] c"file\00" -@fld.str.427 = private constant [5 x i8] c"line\00" -@fld.str.428 = private constant [4 x i8] c"col\00" -@fld.str.429 = private constant [5 x i8] c"func\00" -@fld.str.430 = private constant [10 x i8] c"line_text\00" -@field_names.431 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 4 }, { ptr, i64 } { ptr @fld.str.428, i64 3 }, { ptr, i64 } { ptr @fld.str.429, i64 4 }, { ptr, i64 } { ptr @fld.str.430, i64 9 }] -@str.432 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.433 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.434 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.435 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.436 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.437 = private constant [10 x i8] c"exit_code\00" -@fld.str.438 = private constant [7 x i8] c"stdout\00" -@field_names.439 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.437, i64 9 }, { ptr, i64 } { ptr @fld.str.438, i64 6 }] -@str.440 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.441 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.442 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.443 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.444 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.445 = private constant [8 x i8] c"sin_len\00" -@fld.str.446 = private constant [11 x i8] c"sin_family\00" -@fld.str.447 = private constant [9 x i8] c"sin_port\00" -@fld.str.448 = private constant [9 x i8] c"sin_addr\00" -@fld.str.449 = private constant [9 x i8] c"sin_zero\00" -@field_names.450 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.445, i64 7 }, { ptr, i64 } { ptr @fld.str.446, i64 10 }, { ptr, i64 } { ptr @fld.str.447, i64 8 }, { ptr, i64 } { ptr @fld.str.448, i64 8 }, { ptr, i64 } { ptr @fld.str.449, i64 8 }] -@str.451 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.452 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.453 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.454 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.455 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.456 = private constant [6 x i8] c"items\00" -@fld.str.457 = private constant [4 x i8] c"len\00" -@fld.str.458 = private constant [4 x i8] c"cap\00" -@field_names.459 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.456, i64 5 }, { ptr, i64 } { ptr @fld.str.457, i64 3 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }] -@str.460 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.461 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.462 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.463 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.464 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.465 = private constant [6 x i8] c"items\00" -@fld.str.466 = private constant [4 x i8] c"len\00" -@fld.str.467 = private constant [4 x i8] c"cap\00" -@field_names.468 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.465, i64 5 }, { ptr, i64 } { ptr @fld.str.466, i64 3 }, { ptr, i64 } { ptr @fld.str.467, i64 3 }] -@str.469 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.470 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.471 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.473 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.474 = private constant [4 x i8] c"key\00" -@fld.str.475 = private constant [4 x i8] c"val\00" -@field_names.476 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.474, i64 3 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }] -@str.477 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.478 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.479 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.480 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.481 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.482 = private constant [4 x i8] c"dst\00" -@fld.str.483 = private constant [4 x i8] c"pos\00" -@fld.str.484 = private constant [5 x i8] c"file\00" -@field_names.485 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 4 }] -@str.486 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.487 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.488 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.489 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.490 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.491 = private constant [4 x i8] c"src\00" -@fld.str.492 = private constant [4 x i8] c"pos\00" -@fld.str.493 = private constant [6 x i8] c"alloc\00" -@field_names.494 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.491, i64 3 }, { ptr, i64 } { ptr @fld.str.492, i64 3 }, { ptr, i64 } { ptr @fld.str.493, i64 5 }] -@str.495 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.496 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.497 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.499 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.500 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.502 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.503 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.504 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.505 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.506 = private constant [5 x i8] c"name\00" -@fld.str.507 = private constant [12 x i8] c"takes_value\00" -@fld.str.508 = private constant [9 x i8] c"required\00" -@field_names.509 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.506, i64 4 }, { ptr, i64 } { ptr @fld.str.507, i64 11 }, { ptr, i64 } { ptr @fld.str.508, i64 8 }] -@str.510 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.511 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.512 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.513 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.514 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.515 = private constant [6 x i8] c"group\00" -@fld.str.516 = private constant [8 x i8] c"command\00" -@fld.str.517 = private constant [6 x i8] c"flags\00" -@field_names.518 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.515, i64 5 }, { ptr, i64 } { ptr @fld.str.516, i64 7 }, { ptr, i64 } { ptr @fld.str.517, i64 5 }] -@str.519 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.520 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.521 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.522 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.523 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.524 = private constant [4 x i8] c"set\00" -@fld.str.525 = private constant [6 x i8] c"value\00" -@field_names.526 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.524, i64 3 }, { ptr, i64 } { ptr @fld.str.525, i64 5 }] -@str.527 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.528 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.529 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.530 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.531 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.532 = private constant [6 x i8] c"index\00" -@fld.str.533 = private constant [6 x i8] c"token\00" -@field_names.534 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.532, i64 5 }, { ptr, i64 } { ptr @fld.str.533, i64 5 }] -@str.535 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.536 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.537 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.539 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.540 = private constant [6 x i8] c"group\00" -@fld.str.541 = private constant [8 x i8] c"command\00" -@fld.str.542 = private constant [10 x i8] c"cmd_index\00" -@fld.str.543 = private constant [5 x i8] c"json\00" -@fld.str.544 = private constant [5 x i8] c"rest\00" -@fld.str.545 = private constant [5 x i8] c"spec\00" -@fld.str.546 = private constant [7 x i8] c"values\00" -@field_names.547 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.540, i64 5 }, { ptr, i64 } { ptr @fld.str.541, i64 7 }, { ptr, i64 } { ptr @fld.str.542, i64 9 }, { ptr, i64 } { ptr @fld.str.543, i64 4 }, { ptr, i64 } { ptr @fld.str.544, i64 4 }, { ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 6 }] -@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.549 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.550 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.551 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.552 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.553 = private constant [2 x i8] c"h\00" -@fld.str.554 = private constant [4 x i8] c"buf\00" -@fld.str.555 = private constant [8 x i8] c"buf_len\00" -@fld.str.556 = private constant [10 x i8] c"total_len\00" -@field_names.557 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.553, i64 1 }, { ptr, i64 } { ptr @fld.str.554, i64 3 }, { ptr, i64 } { ptr @fld.str.555, i64 7 }, { ptr, i64 } { ptr @fld.str.556, i64 9 }] -@str.558 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.559 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.560 = private constant [5 x i8] c"read\00" -@fld.str.561 = private constant [6 x i8] c"write\00" -@fld.str.562 = private constant [7 x i8] c"append\00" -@fld.str.563 = private constant [11 x i8] c"read_write\00" -@field_names.564 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.560, i64 4 }, { ptr, i64 } { ptr @fld.str.561, i64 5 }, { ptr, i64 } { ptr @fld.str.562, i64 6 }, { ptr, i64 } { ptr @fld.str.563, i64 10 }] -@str.565 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.566 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.567 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.568 = private constant [4 x i8] c"set\00" -@fld.str.569 = private constant [8 x i8] c"current\00" -@fld.str.570 = private constant [4 x i8] c"end\00" -@field_names.571 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.568, i64 3 }, { ptr, i64 } { ptr @fld.str.569, i64 7 }, { ptr, i64 } { ptr @fld.str.570, i64 3 }] -@str.572 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.573 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.574 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.575 = private constant [6 x i8] c"null_\00" -@fld.str.576 = private constant [6 x i8] c"bool_\00" -@fld.str.577 = private constant [5 x i8] c"int_\00" -@fld.str.578 = private constant [4 x i8] c"str\00" -@fld.str.579 = private constant [6 x i8] c"array\00" -@fld.str.580 = private constant [7 x i8] c"object\00" -@field_names.581 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 4 }, { ptr, i64 } { ptr @fld.str.578, i64 3 }, { ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 6 }] -@str.582 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.585 = private constant [6 x i8] c"macos\00" -@fld.str.586 = private constant [6 x i8] c"linux\00" -@fld.str.587 = private constant [8 x i8] c"windows\00" -@fld.str.588 = private constant [5 x i8] c"wasm\00" -@fld.str.589 = private constant [4 x i8] c"ios\00" -@fld.str.590 = private constant [8 x i8] c"android\00" -@fld.str.591 = private constant [8 x i8] c"unknown\00" -@field_names.592 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 5 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 4 }, { ptr, i64 } { ptr @fld.str.589, i64 3 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }] -@str.593 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.594 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.595 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.596 = private constant [8 x i8] c"aarch64\00" -@fld.str.597 = private constant [7 x i8] c"x86_64\00" -@fld.str.598 = private constant [7 x i8] c"wasm32\00" -@fld.str.599 = private constant [7 x i8] c"wasm64\00" -@fld.str.600 = private constant [8 x i8] c"unknown\00" -@field_names.601 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.596, i64 7 }, { ptr, i64 } { ptr @fld.str.597, i64 6 }, { ptr, i64 } { ptr @fld.str.598, i64 6 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 7 }] -@str.602 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.634 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.635 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.636 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.638 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.639 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.641 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.644 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.647 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.650 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.653 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.656 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.659 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.662 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.665 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.668 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.674 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.677 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.680 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.683 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.686 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.689 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.692 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.722 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.725 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.728 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.729 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.731 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 -@str.732 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.347 = private constant [5 x i8] c"line\00" +@fld.str.348 = private constant [4 x i8] c"col\00" +@fld.str.349 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.347, i64 4 }, { ptr, i64 } { ptr @fld.str.348, i64 3 }, { ptr, i64 } { ptr @fld.str.349, i64 4 }] +@str.350 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.351 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.355 = private constant [4 x i8] c"ctx\00" +@fld.str.356 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.357 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.358 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.355, i64 3 }, { ptr, i64 } { ptr @fld.str.356, i64 11 }, { ptr, i64 } { ptr @fld.str.357, i64 13 }] +@str.359 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.360 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.361 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.363 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.364 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.365 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.366 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.367 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.368 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.369 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.370 = private constant [12 x i8] c"alloc_count\00" +@field_names.371 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.370, i64 11 }] +@str.372 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.373 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.374 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.375 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.376 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.377 = private constant [5 x i8] c"next\00" +@fld.str.378 = private constant [4 x i8] c"cap\00" +@field_names.379 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.377, i64 4 }, { ptr, i64 } { ptr @fld.str.378, i64 3 }] +@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.381 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.385 = private constant [6 x i8] c"first\00" +@fld.str.386 = private constant [10 x i8] c"end_index\00" +@fld.str.387 = private constant [7 x i8] c"parent\00" +@field_names.388 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 5 }, { ptr, i64 } { ptr @fld.str.386, i64 9 }, { ptr, i64 } { ptr @fld.str.387, i64 6 }] +@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.390 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.394 = private constant [4 x i8] c"buf\00" +@fld.str.395 = private constant [4 x i8] c"len\00" +@fld.str.396 = private constant [4 x i8] c"pos\00" +@field_names.397 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 3 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }, { ptr, i64 } { ptr @fld.str.396, i64 3 }] +@str.398 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.399 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.401 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.402 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.403 = private constant [7 x i8] c"parent\00" +@fld.str.404 = private constant [12 x i8] c"alloc_count\00" +@fld.str.405 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.406 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.407 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.403, i64 6 }, { ptr, i64 } { ptr @fld.str.404, i64 11 }, { ptr, i64 } { ptr @fld.str.405, i64 13 }, { ptr, i64 } { ptr @fld.str.406, i64 17 }] +@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.409 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.413 = private constant [10 x i8] c"allocator\00" +@fld.str.414 = private constant [5 x i8] c"data\00" +@field_names.415 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 9 }, { ptr, i64 } { ptr @fld.str.414, i64 4 }] +@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.417 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.421 = private constant [3 x i8] c"fd\00" +@field_names.422 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 2 }] +@str.423 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.424 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.425 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.426 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.427 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.428 = private constant [5 x i8] c"file\00" +@fld.str.429 = private constant [5 x i8] c"line\00" +@fld.str.430 = private constant [4 x i8] c"col\00" +@fld.str.431 = private constant [5 x i8] c"func\00" +@fld.str.432 = private constant [10 x i8] c"line_text\00" +@field_names.433 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.428, i64 4 }, { ptr, i64 } { ptr @fld.str.429, i64 4 }, { ptr, i64 } { ptr @fld.str.430, i64 3 }, { ptr, i64 } { ptr @fld.str.431, i64 4 }, { ptr, i64 } { ptr @fld.str.432, i64 9 }] +@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.435 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.436 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.437 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.438 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.439 = private constant [10 x i8] c"exit_code\00" +@fld.str.440 = private constant [7 x i8] c"stdout\00" +@field_names.441 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 9 }, { ptr, i64 } { ptr @fld.str.440, i64 6 }] +@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.443 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.447 = private constant [8 x i8] c"sin_len\00" +@fld.str.448 = private constant [11 x i8] c"sin_family\00" +@fld.str.449 = private constant [9 x i8] c"sin_port\00" +@fld.str.450 = private constant [9 x i8] c"sin_addr\00" +@fld.str.451 = private constant [9 x i8] c"sin_zero\00" +@field_names.452 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 7 }, { ptr, i64 } { ptr @fld.str.448, i64 10 }, { ptr, i64 } { ptr @fld.str.449, i64 8 }, { ptr, i64 } { ptr @fld.str.450, i64 8 }, { ptr, i64 } { ptr @fld.str.451, i64 8 }] +@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.454 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.458 = private constant [6 x i8] c"items\00" +@fld.str.459 = private constant [4 x i8] c"len\00" +@fld.str.460 = private constant [4 x i8] c"cap\00" +@field_names.461 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 5 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }] +@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.463 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.467 = private constant [6 x i8] c"items\00" +@fld.str.468 = private constant [4 x i8] c"len\00" +@fld.str.469 = private constant [4 x i8] c"cap\00" +@field_names.470 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 5 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }] +@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.472 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.476 = private constant [4 x i8] c"key\00" +@fld.str.477 = private constant [4 x i8] c"val\00" +@field_names.478 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }] +@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.480 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.484 = private constant [4 x i8] c"dst\00" +@fld.str.485 = private constant [4 x i8] c"pos\00" +@fld.str.486 = private constant [5 x i8] c"file\00" +@field_names.487 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 4 }] +@str.488 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.489 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.490 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.491 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.492 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.493 = private constant [4 x i8] c"src\00" +@fld.str.494 = private constant [4 x i8] c"pos\00" +@fld.str.495 = private constant [6 x i8] c"alloc\00" +@field_names.496 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 3 }, { ptr, i64 } { ptr @fld.str.495, i64 5 }] +@str.497 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.498 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.499 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.501 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.502 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.504 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.505 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.506 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.507 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.508 = private constant [5 x i8] c"name\00" +@fld.str.509 = private constant [12 x i8] c"takes_value\00" +@fld.str.510 = private constant [9 x i8] c"required\00" +@field_names.511 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.508, i64 4 }, { ptr, i64 } { ptr @fld.str.509, i64 11 }, { ptr, i64 } { ptr @fld.str.510, i64 8 }] +@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.513 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.514 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.515 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.516 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.517 = private constant [6 x i8] c"group\00" +@fld.str.518 = private constant [8 x i8] c"command\00" +@fld.str.519 = private constant [6 x i8] c"flags\00" +@field_names.520 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.517, i64 5 }, { ptr, i64 } { ptr @fld.str.518, i64 7 }, { ptr, i64 } { ptr @fld.str.519, i64 5 }] +@str.521 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.522 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.523 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.524 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.525 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.526 = private constant [4 x i8] c"set\00" +@fld.str.527 = private constant [6 x i8] c"value\00" +@field_names.528 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.526, i64 3 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] +@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.530 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.534 = private constant [6 x i8] c"index\00" +@fld.str.535 = private constant [6 x i8] c"token\00" +@field_names.536 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 5 }, { ptr, i64 } { ptr @fld.str.535, i64 5 }] +@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.538 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.542 = private constant [6 x i8] c"group\00" +@fld.str.543 = private constant [8 x i8] c"command\00" +@fld.str.544 = private constant [10 x i8] c"cmd_index\00" +@fld.str.545 = private constant [5 x i8] c"json\00" +@fld.str.546 = private constant [5 x i8] c"rest\00" +@fld.str.547 = private constant [5 x i8] c"spec\00" +@fld.str.548 = private constant [7 x i8] c"values\00" +@field_names.549 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 5 }, { ptr, i64 } { ptr @fld.str.543, i64 7 }, { ptr, i64 } { ptr @fld.str.544, i64 9 }, { ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 4 }, { ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 6 }] +@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.551 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.552 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.553 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.554 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.555 = private constant [2 x i8] c"h\00" +@fld.str.556 = private constant [4 x i8] c"buf\00" +@fld.str.557 = private constant [8 x i8] c"buf_len\00" +@fld.str.558 = private constant [10 x i8] c"total_len\00" +@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 1 }, { ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 9 }] +@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.561 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.562 = private constant [5 x i8] c"read\00" +@fld.str.563 = private constant [6 x i8] c"write\00" +@fld.str.564 = private constant [7 x i8] c"append\00" +@fld.str.565 = private constant [11 x i8] c"read_write\00" +@field_names.566 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 4 }, { ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 6 }, { ptr, i64 } { ptr @fld.str.565, i64 10 }] +@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.570 = private constant [4 x i8] c"set\00" +@fld.str.571 = private constant [8 x i8] c"current\00" +@fld.str.572 = private constant [4 x i8] c"end\00" +@field_names.573 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 7 }, { ptr, i64 } { ptr @fld.str.572, i64 3 }] +@str.574 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.575 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.576 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.577 = private constant [6 x i8] c"null_\00" +@fld.str.578 = private constant [6 x i8] c"bool_\00" +@fld.str.579 = private constant [5 x i8] c"int_\00" +@fld.str.580 = private constant [4 x i8] c"str\00" +@fld.str.581 = private constant [6 x i8] c"array\00" +@fld.str.582 = private constant [7 x i8] c"object\00" +@field_names.583 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 3 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 6 }] +@str.584 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.587 = private constant [6 x i8] c"macos\00" +@fld.str.588 = private constant [6 x i8] c"linux\00" +@fld.str.589 = private constant [8 x i8] c"windows\00" +@fld.str.590 = private constant [5 x i8] c"wasm\00" +@fld.str.591 = private constant [4 x i8] c"ios\00" +@fld.str.592 = private constant [8 x i8] c"android\00" +@fld.str.593 = private constant [8 x i8] c"unknown\00" +@field_names.594 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 5 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 4 }, { ptr, i64 } { ptr @fld.str.591, i64 3 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }] +@str.595 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.596 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.597 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.598 = private constant [8 x i8] c"aarch64\00" +@fld.str.599 = private constant [7 x i8] c"x86_64\00" +@fld.str.600 = private constant [7 x i8] c"wasm32\00" +@fld.str.601 = private constant [7 x i8] c"wasm64\00" +@fld.str.602 = private constant [8 x i8] c"unknown\00" +@field_names.603 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.598, i64 7 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 6 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 7 }] +@str.604 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.635 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.636 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.637 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.638 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.640 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.641 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.643 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.646 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.649 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.652 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.655 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.658 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.661 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.664 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.667 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.670 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.676 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.679 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.682 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.688 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.691 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.694 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.724 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.727 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.730 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.733 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -632,6 +632,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -851,7 +854,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -978,7 +981,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1312,7 +1315,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1462,7 +1465,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1488,9 +1491,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1532,9 +1535,9 @@ entry: i64 85, label %match.arm.48 i64 96, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1574,7 +1577,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1618,9 +1621,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1702,9 +1705,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.340 [ i64 18, label %dispatch.case.341 - i64 21, label %dispatch.case.342 - i64 23, label %dispatch.case.343 - i64 25, label %dispatch.case.344 + i64 22, label %dispatch.case.342 + i64 24, label %dispatch.case.343 + i64 26, label %dispatch.case.344 i64 28, label %dispatch.case.345 i64 29, label %dispatch.case.346 i64 31, label %dispatch.case.347 @@ -1802,7 +1805,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1816,32 +1819,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2011,7 +2014,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2052,7 +2055,7 @@ dispatch.merge.263: ; preds = %dispatch.case.271, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2117,7 +2120,7 @@ dispatch.merge.307: ; preds = %dispatch.case.313, br label %match.merge.37 dispatch.default.308: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2166,7 +2169,7 @@ dispatch.merge.339: ; preds = %dispatch.case.371, br label %match.merge.37 dispatch.default.340: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2392,7 +2395,7 @@ dispatch.merge.478: ; preds = %dispatch.case.483, br label %match.merge.37 dispatch.default.479: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2434,7 +2437,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.311, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2530,7 +2533,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2538,7 +2541,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2548,13 +2551,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2562,7 +2565,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2576,7 +2579,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2584,7 +2587,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2595,7 +2598,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2652,7 +2655,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2660,7 +2663,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2671,7 +2674,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2691,7 +2694,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2699,7 +2702,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, 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 @@ -2710,7 +2713,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2720,64 +2723,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2953,163 +2959,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3307,64 +3316,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3394,97 +3403,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3523,7 +3532,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @scale(ptr %0, i32 %1, i32 %2) #0 { @@ -3562,9 +3571,9 @@ entry: call void @print__ct_sc20f1d9fe3bc82ac__pack_s32(ptr @__sx_default_context, i32 %call) %callN = call i32 @scale(ptr @__sx_default_context, i32 5, i32 3) call void @print__ct_sfb0b0da1195bd991__pack_s32(ptr @__sx_default_context, i32 %callN) - %callN = call i32 @label(ptr @__sx_default_context, i32 1, { ptr, i64 } { ptr @str.326, i64 1 }, { ptr, i64 } { ptr @str.327, i64 1 }) - %callN = call i32 @label(ptr @__sx_default_context, i32 2, { ptr, i64 } { ptr @str.328, i64 1 }, { ptr, i64 } { ptr @str.329, i64 1 }) - %callN = call i32 @label(ptr @__sx_default_context, i32 3, { ptr, i64 } { ptr @str.330, i64 1 }, { ptr, i64 } { ptr @str.331, i64 1 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 1, { ptr, i64 } { ptr @str.328, i64 1 }, { ptr, i64 } { ptr @str.329, i64 1 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 2, { ptr, i64 } { ptr @str.330, i64 1 }, { ptr, i64 } { ptr @str.331, i64 1 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 3, { ptr, i64 } { ptr @str.332, i64 1 }, { ptr, i64 } { ptr @str.333, i64 1 }) ret i32 0 } @@ -3586,7 +3595,7 @@ entry: define internal void @print__ct_sc20f1d9fe3bc82ac__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.332, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.334, i64 12 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3602,7 +3611,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 9) @@ -3630,7 +3639,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.334, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.336, i64 12 }) ret { ptr, i64 } %call } @@ -3638,7 +3647,7 @@ entry: define internal void @print__ct_sfb0b0da1195bd991__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.335, i64 13 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.337, i64 13 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3654,7 +3663,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.338, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 10) @@ -3682,7 +3691,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.337, i64 13 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.339, i64 13 }) ret { ptr, i64 } %call } @@ -3690,7 +3699,7 @@ entry: define internal void @print__ct_s7d5f90608c43cc01__pack_string_s32_string(ptr %0, { ptr, i64 } %1, i32 %2, { ptr, i64 } %3) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.338, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.340, i64 7 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %allocaN, align 8 %allocaN = alloca i32, align 4 @@ -3724,7 +3733,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 3, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.339, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.341, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %ba.tmp19 = alloca { ptr, i64 }, align 8 @@ -3765,7 +3774,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.340, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.342, i64 7 }) ret { ptr, i64 } %call } @@ -3776,7 +3785,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.341, i64 15 }, { ptr, i64 } { ptr @str.342, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 15 }, { ptr, i64 } { ptr @str.344, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3795,12 +3804,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3812,7 +3821,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3865,20 +3874,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.349, i64 10 }, { ptr, i64 } { ptr @str.350, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 9 }, { ptr, i64 } { ptr @str.352, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3888,224 +3897,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.353, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.358, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 3 }, { ptr, i64 } { ptr @str.356, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.360, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.362, i64 10 }, { ptr, i64 } { ptr @str.363, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.368, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 9 }, { ptr, i64 } { ptr @str.371, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.377, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, 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 @@ -4124,27 +3933,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.360, i64 10 }, { ptr, i64 } { ptr @str.361, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.364, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.366, i64 3 }, { ptr, i64 } { ptr @str.367, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.371, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.373, i64 10 }, { ptr, i64 } { ptr @str.374, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.379, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4154,7 +4163,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 5 }, { ptr, i64 } { ptr @str.380, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 5 }, { ptr, i64 } { ptr @str.382, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4173,24 +4182,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.386, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.388, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, 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 @@ -4217,7 +4226,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4229,7 +4238,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4238,7 +4247,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 8 }, { ptr, i64 } { ptr @str.389, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 8 }, { ptr, i64 } { ptr @str.391, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4257,24 +4266,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.395, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.397, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, 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 @@ -4321,7 +4330,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.397, i64 17 }, { ptr, i64 } { ptr @str.398, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 17 }, { ptr, i64 } { ptr @str.400, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4340,24 +4349,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.405, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4386,7 +4395,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4411,7 +4420,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 7 }, { ptr, i64 } { ptr @str.408, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 7 }, { ptr, i64 } { ptr @str.410, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4430,24 +4439,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.413, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.415, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, 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 @@ -4474,7 +4483,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4489,7 +4498,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.415, i64 4 }, { ptr, i64 } { ptr @str.416, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 4 }, { ptr, i64 } { ptr @str.418, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4508,24 +4517,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.420, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.422, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4562,7 +4571,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.422, i64 10 }, { ptr, i64 } { ptr @str.423, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.424, i64 10 }, { ptr, i64 } { ptr @str.425, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4581,24 +4590,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.431, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.433, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4664,7 +4673,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.433, i64 13 }, { ptr, i64 } { ptr @str.434, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 13 }, { ptr, i64 } { ptr @str.436, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4683,24 +4692,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.439, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.441, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4742,7 +4751,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.441, i64 8 }, { ptr, i64 } { ptr @str.442, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 8 }, { ptr, i64 } { ptr @str.444, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4761,24 +4770,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.450, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.452, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4839,7 +4848,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.452, i64 5 }, { ptr, i64 } { ptr @str.453, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 5 }, { ptr, i64 } { ptr @str.455, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4858,24 +4867,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.459, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.461, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, 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 @@ -4921,7 +4930,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.461, i64 6 }, { ptr, i64 } { ptr @str.462, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 6 }, { ptr, i64 } { ptr @str.464, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4940,24 +4949,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.468, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.470, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, 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 @@ -5005,7 +5014,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.470, i64 6 }, { ptr, i64 } { ptr @str.471, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 6 }, { ptr, i64 } { ptr @str.473, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5024,24 +5033,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.476, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.478, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5085,7 +5094,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.478, i64 4 }, { ptr, i64 } { ptr @str.479, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 4 }, { ptr, i64 } { ptr @str.481, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5104,24 +5113,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.485, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.487, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5171,7 +5180,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.487, i64 6 }, { ptr, i64 } { ptr @str.488, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 6 }, { ptr, i64 } { ptr @str.490, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5190,24 +5199,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.494, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.496, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5247,7 +5256,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5256,7 +5265,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.496, i64 12 }, { ptr, i64 } { ptr @str.497, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.498, i64 12 }, { ptr, i64 } { ptr @str.499, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5275,24 +5284,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.500, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.502, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5312,7 +5321,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 8 }, { ptr, i64 } { ptr @str.503, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 8 }, { ptr, i64 } { ptr @str.505, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5331,24 +5340,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.509, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.511, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5400,7 +5409,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.511, i64 7 }, { ptr, i64 } { ptr @str.512, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 7 }, { ptr, i64 } { ptr @str.514, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5419,24 +5428,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.518, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.520, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5488,7 +5497,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.520, i64 9 }, { ptr, i64 } { ptr @str.521, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.522, i64 9 }, { ptr, i64 } { ptr @str.523, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5507,24 +5516,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.526, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.528, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5567,7 +5576,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.528, i64 4 }, { ptr, i64 } { ptr @str.529, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 4 }, { ptr, i64 } { ptr @str.531, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5586,24 +5595,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.534, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.536, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5649,7 +5658,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.536, i64 6 }, { ptr, i64 } { ptr @str.537, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 6 }, { ptr, i64 } { ptr @str.539, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5668,24 +5677,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.547, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.549, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5767,7 +5776,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 6 }, { ptr, i64 } { ptr @str.550, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, i64 6 }, { ptr, i64 } { ptr @str.552, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5786,24 +5795,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.557, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.558, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5862,9 +5871,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.564, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, 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 @@ -5883,8 +5892,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.565, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5903,9 +5912,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.571, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.573, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, 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 @@ -5924,8 +5933,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5955,9 +5964,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.581, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5974,8 +5983,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -6053,9 +6062,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.592, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.594, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, 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 @@ -6074,8 +6083,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.593, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.595, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -6094,9 +6103,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.601, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.595, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, 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 @@ -6115,8 +6124,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.602, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6133,7 +6142,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.272 @@ -6150,12 +6159,12 @@ while.body.273: ; preds = %while.hdr.272 while.exit.274: ; preds = %while.hdr.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %call if.then.275: ; preds = %while.body.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 @@ -6184,7 +6193,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.277 @@ -6201,12 +6210,12 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %call if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 @@ -6236,7 +6245,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.282 @@ -6253,12 +6262,12 @@ while.body.283: ; preds = %while.hdr.282 while.exit.284: ; preds = %while.hdr.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %call if.then.285: ; preds = %while.body.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6286,7 +6295,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.287 @@ -6303,12 +6312,12 @@ while.body.288: ; preds = %while.hdr.287 while.exit.289: ; preds = %while.hdr.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %call if.then.290: ; preds = %while.body.288 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -6337,7 +6346,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.292 @@ -6354,12 +6363,12 @@ while.body.293: ; preds = %while.hdr.292 while.exit.294: ; preds = %while.hdr.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) ret { ptr, i64 } %call if.then.295: ; preds = %while.body.293 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6388,7 +6397,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.297 @@ -6405,12 +6414,12 @@ while.body.298: ; preds = %while.hdr.297 while.exit.299: ; preds = %while.hdr.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) ret { ptr, i64 } %call if.then.300: ; preds = %while.body.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.301 @@ -6441,7 +6450,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.302 @@ -6458,12 +6467,12 @@ while.body.303: ; preds = %while.hdr.302 while.exit.304: ; preds = %while.hdr.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %call if.then.305: ; preds = %while.body.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.306 @@ -6493,7 +6502,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6512,12 +6521,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6546,7 +6555,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.319 @@ -6565,12 +6574,12 @@ while.body.320: ; preds = %while.hdr.319 while.exit.321: ; preds = %while.hdr.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) ret { ptr, i64 } %call if.then.322: ; preds = %while.body.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.323 @@ -6599,7 +6608,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.631, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.633, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.324 @@ -6618,12 +6627,12 @@ while.body.325: ; preds = %while.hdr.324 while.exit.326: ; preds = %while.hdr.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) ret { ptr, i64 } %call if.then.327: ; preds = %while.body.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.328 @@ -6653,7 +6662,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.634, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.636, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.329 @@ -6672,12 +6681,12 @@ while.body.330: ; preds = %while.hdr.329 while.exit.331: ; preds = %while.hdr.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) ret { ptr, i64 } %call if.then.332: ; preds = %while.body.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.333 @@ -6707,7 +6716,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.637, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.639, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.334 @@ -6726,12 +6735,12 @@ while.body.335: ; preds = %while.hdr.334 while.exit.336: ; preds = %while.hdr.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 1 }) ret { ptr, i64 } %call if.then.337: ; preds = %while.body.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.641, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.338 @@ -6773,12 +6782,12 @@ if.then.372: ; preds = %entry if.else.373: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 5 }, { ptr, i64 } %callN) br label %if.merge.374 if.merge.374: ; preds = %if.else.373, %if.then.372 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6801,12 +6810,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6829,12 +6838,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 4 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6857,12 +6866,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 11 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6885,12 +6894,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 6 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6912,12 +6921,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 5 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6940,12 +6949,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 9 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6968,12 +6977,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 18 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6996,12 +7005,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 5 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -7024,12 +7033,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -7052,12 +7061,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -7080,12 +7089,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 9 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7108,12 +7117,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 4 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7135,12 +7144,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 8 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7163,12 +7172,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 6 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7190,12 +7199,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 9 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7218,12 +7227,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7246,12 +7255,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 5 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7274,12 +7283,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7302,12 +7311,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 4 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7330,12 +7339,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7358,12 +7367,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 5 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7386,12 +7395,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 7 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7414,12 +7423,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 12 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7442,12 +7451,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 6 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7470,12 +7479,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7498,12 +7507,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 4 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7526,12 +7535,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 7 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7554,12 +7563,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 6 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7582,12 +7591,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 5 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7610,12 +7619,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 7 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7631,7 +7640,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.733, i64 4 } + ret { ptr, i64 } { ptr @str.735, i64 4 } if.merge.485: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7655,7 +7664,7 @@ entry: br i1 %lnot, label %if.then.486, label %if.merge.487 if.then.486: ; preds = %entry - ret { ptr, i64 } { ptr @str.734, i64 4 } + ret { ptr, i64 } { ptr @str.736, i64 4 } if.merge.487: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7679,7 +7688,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.735, i64 4 } + ret { ptr, i64 } { ptr @str.737, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7703,7 +7712,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.736, i64 4 } + ret { ptr, i64 } { ptr @str.738, i64 4 } if.merge.491: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0107-types-int-cmp-in-float-ternary.ir b/examples/expected/0107-types-int-cmp-in-float-ternary.ir index 0c73761..bdf5715 100644 --- a/examples/expected/0107-types-int-cmp-in-float-ternary.ir +++ b/examples/expected/0107-types-int-cmp-in-float-ternary.ir @@ -1,610 +1,610 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [161 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [5 x i8] c"*f32\00" -@tn.str.239 = private constant [8 x i8] c"*string\00" -@tn.str.240 = private constant [6 x i8] c"[]Any\00" -@tn.str.241 = private constant [5 x i8] c"*Any\00" -@tn.str.242 = private constant [7 x i8] c"[1]Any\00" -@tn.str.243 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.244 = private constant [7 x i8] c"*[]Any\00" -@tn.str.245 = private constant [6 x i8] c"*bool\00" -@tn.str.246 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.247 = private constant [5 x i8] c"*f64\00" -@tn.str.248 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.249 = private constant [11 x i8] c"*Allocator\00" -@tn.str.250 = private constant [9 x i8] c"*Context\00" -@tn.str.251 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.252 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.253 = private constant [8 x i8] c"*Member\00" -@tn.str.254 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.255 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.256 = private constant [9 x i8] c"*Command\00" -@tn.str.257 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.258 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.259 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.260 = private constant [7 x i8] c"*Value\00" -@tn.str.261 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.262 = private constant [14 x i8] c"*Architecture\00" -@tn.str.263 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.264 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.265 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.266 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.267 = private constant [10 x i8] c"*[]string\00" -@tn.str.268 = private constant [6 x i8] c"*[]u8\00" -@tn.str.269 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.270 = private constant [11 x i8] c"*[]Command\00" -@tn.str.271 = private constant [6 x i8] c"**GPA\00" -@tn.str.272 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.273 = private constant [8 x i8] c"**Arena\00" -@tn.str.274 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.275 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.276 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.277 = private constant [7 x i8] c"**File\00" -@tn.str.278 = private constant [5 x i8] c"**u8\00" -@tn.str.279 = private constant [6 x i8] c"**s32\00" -@tn.str.280 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.281 = private constant [6 x i8] c"**u32\00" -@tn.str.282 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.283 = private constant [8 x i8] c"**Array\00" -@tn.str.284 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.285 = private constant [9 x i8] c"**Object\00" -@tn.str.286 = private constant [7 x i8] c"**Sink\00" -@tn.str.287 = private constant [9 x i8] c"**Parser\00" -@tn.str.288 = private constant [6 x i8] c"**s64\00" -@tn.str.289 = private constant [9 x i8] c"**Parsed\00" -@tn.str.290 = private constant [7 x i8] c"**Diag\00" -@tn.str.291 = private constant [9 x i8] c"**Sha256\00" -@tn.str.292 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.293 = private constant [8 x i8] c"***void\00" -@tn.str.294 = private constant [6 x i8] c"**f32\00" -@tn.str.295 = private constant [9 x i8] c"**string\00" -@tn.str.296 = private constant [6 x i8] c"**Any\00" -@tn.str.297 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.298 = private constant [8 x i8] c"**[]Any\00" -@tn.str.299 = private constant [7 x i8] c"**bool\00" -@tn.str.300 = private constant [7 x i8] c"*?File\00" -@tn.str.301 = private constant [9 x i8] c"*?string\00" -@tn.str.302 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.303 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [161 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 4 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 5 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 4 }, { ptr, i64 } { ptr @tn.str.248, i64 16 }, { ptr, i64 } { ptr @tn.str.249, i64 10 }, { ptr, i64 } { ptr @tn.str.250, i64 8 }, { ptr, i64 } { ptr @tn.str.251, i64 11 }, { ptr, i64 } { ptr @tn.str.252, i64 14 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 13 }, { ptr, i64 } { ptr @tn.str.255, i64 9 }, { ptr, i64 } { ptr @tn.str.256, i64 8 }, { ptr, i64 } { ptr @tn.str.257, i64 10 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 6 }, { ptr, i64 } { ptr @tn.str.261, i64 16 }, { ptr, i64 } { ptr @tn.str.262, i64 13 }, { ptr, i64 } { ptr @tn.str.263, i64 14 }, { ptr, i64 } { ptr @tn.str.264, i64 7 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 8 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 5 }, { ptr, i64 } { ptr @tn.str.269, i64 11 }, { ptr, i64 } { ptr @tn.str.270, i64 10 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 12 }, { ptr, i64 } { ptr @tn.str.273, i64 7 }, { ptr, i64 } { ptr @tn.str.274, i64 6 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 19 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 4 }, { ptr, i64 } { ptr @tn.str.279, i64 5 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 9 }, { ptr, i64 } { ptr @tn.str.283, i64 7 }, { ptr, i64 } { ptr @tn.str.284, i64 10 }, { ptr, i64 } { ptr @tn.str.285, i64 8 }, { ptr, i64 } { ptr @tn.str.286, i64 6 }, { ptr, i64 } { ptr @tn.str.287, i64 8 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 8 }, { ptr, i64 } { ptr @tn.str.290, i64 6 }, { ptr, i64 } { ptr @tn.str.291, i64 8 }, { ptr, i64 } { ptr @tn.str.292, i64 13 }, { ptr, i64 } { ptr @tn.str.293, i64 7 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 6 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 15 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }] -@str.304 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [5 x i8] c"*f32\00" +@tn.str.241 = private constant [8 x i8] c"*string\00" +@tn.str.242 = private constant [6 x i8] c"[]Any\00" +@tn.str.243 = private constant [5 x i8] c"*Any\00" +@tn.str.244 = private constant [7 x i8] c"[1]Any\00" +@tn.str.245 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.246 = private constant [7 x i8] c"*[]Any\00" +@tn.str.247 = private constant [6 x i8] c"*bool\00" +@tn.str.248 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.249 = private constant [5 x i8] c"*f64\00" +@tn.str.250 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.251 = private constant [11 x i8] c"*Allocator\00" +@tn.str.252 = private constant [9 x i8] c"*Context\00" +@tn.str.253 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.254 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.255 = private constant [8 x i8] c"*Member\00" +@tn.str.256 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.257 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.258 = private constant [9 x i8] c"*Command\00" +@tn.str.259 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.260 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.261 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.262 = private constant [7 x i8] c"*Value\00" +@tn.str.263 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.264 = private constant [14 x i8] c"*Architecture\00" +@tn.str.265 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.266 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.267 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.268 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.269 = private constant [10 x i8] c"*[]string\00" +@tn.str.270 = private constant [6 x i8] c"*[]u8\00" +@tn.str.271 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.272 = private constant [11 x i8] c"*[]Command\00" +@tn.str.273 = private constant [6 x i8] c"**GPA\00" +@tn.str.274 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.275 = private constant [8 x i8] c"**Arena\00" +@tn.str.276 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.277 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.278 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.279 = private constant [7 x i8] c"**File\00" +@tn.str.280 = private constant [5 x i8] c"**u8\00" +@tn.str.281 = private constant [6 x i8] c"**s32\00" +@tn.str.282 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.283 = private constant [6 x i8] c"**u32\00" +@tn.str.284 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.285 = private constant [8 x i8] c"**Array\00" +@tn.str.286 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.287 = private constant [9 x i8] c"**Object\00" +@tn.str.288 = private constant [7 x i8] c"**Sink\00" +@tn.str.289 = private constant [9 x i8] c"**Parser\00" +@tn.str.290 = private constant [6 x i8] c"**s64\00" +@tn.str.291 = private constant [9 x i8] c"**Parsed\00" +@tn.str.292 = private constant [7 x i8] c"**Diag\00" +@tn.str.293 = private constant [9 x i8] c"**Sha256\00" +@tn.str.294 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.295 = private constant [8 x i8] c"***void\00" +@tn.str.296 = private constant [6 x i8] c"**f32\00" +@tn.str.297 = private constant [9 x i8] c"**string\00" +@tn.str.298 = private constant [6 x i8] c"**Any\00" +@tn.str.299 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.300 = private constant [8 x i8] c"**[]Any\00" +@tn.str.301 = private constant [7 x i8] c"**bool\00" +@tn.str.302 = private constant [7 x i8] c"*?File\00" +@tn.str.303 = private constant [9 x i8] c"*?string\00" +@tn.str.304 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.305 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [161 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 5 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 5 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 4 }, { ptr, i64 } { ptr @tn.str.250, i64 16 }, { ptr, i64 } { ptr @tn.str.251, i64 10 }, { ptr, i64 } { ptr @tn.str.252, i64 8 }, { ptr, i64 } { ptr @tn.str.253, i64 11 }, { ptr, i64 } { ptr @tn.str.254, i64 14 }, { ptr, i64 } { ptr @tn.str.255, i64 7 }, { ptr, i64 } { ptr @tn.str.256, i64 13 }, { ptr, i64 } { ptr @tn.str.257, i64 9 }, { ptr, i64 } { ptr @tn.str.258, i64 8 }, { ptr, i64 } { ptr @tn.str.259, i64 10 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 6 }, { ptr, i64 } { ptr @tn.str.263, i64 16 }, { ptr, i64 } { ptr @tn.str.264, i64 13 }, { ptr, i64 } { ptr @tn.str.265, i64 14 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 8 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 5 }, { ptr, i64 } { ptr @tn.str.271, i64 11 }, { ptr, i64 } { ptr @tn.str.272, i64 10 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 12 }, { ptr, i64 } { ptr @tn.str.275, i64 7 }, { ptr, i64 } { ptr @tn.str.276, i64 6 }, { ptr, i64 } { ptr @tn.str.277, i64 10 }, { ptr, i64 } { ptr @tn.str.278, i64 19 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 4 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 10 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 9 }, { ptr, i64 } { ptr @tn.str.285, i64 7 }, { ptr, i64 } { ptr @tn.str.286, i64 10 }, { ptr, i64 } { ptr @tn.str.287, i64 8 }, { ptr, i64 } { ptr @tn.str.288, i64 6 }, { ptr, i64 } { ptr @tn.str.289, i64 8 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 8 }, { ptr, i64 } { ptr @tn.str.292, i64 6 }, { ptr, i64 } { ptr @tn.str.293, i64 8 }, { ptr, i64 } { ptr @tn.str.294, i64 13 }, { ptr, i64 } { ptr @tn.str.295, i64 7 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 15 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }] @str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.310 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.311 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.312 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.313 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.314 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.315 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.316 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.317 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.318 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.325 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.326 = private unnamed_addr constant [13 x i8] c"result = {}\0A\00", align 1 -@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.312 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.313 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.314 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.315 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.316 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.317 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.324 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.325 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.326 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.327 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 @str.328 = private unnamed_addr constant [13 x i8] c"result = {}\0A\00", align 1 -@str.329 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.330 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.331 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.332 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [13 x i8] c"result = {}\0A\00", align 1 +@str.331 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.332 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.333 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.334 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.333 = private constant [5 x i8] c"line\00" -@fld.str.334 = private constant [4 x i8] c"col\00" -@fld.str.335 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.333, i64 4 }, { ptr, i64 } { ptr @fld.str.334, i64 3 }, { ptr, i64 } { ptr @fld.str.335, i64 4 }] -@str.336 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.337 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.338 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.339 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.341 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.342 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.343 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.347 = private constant [12 x i8] c"alloc_count\00" -@field_names.348 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.347, i64 11 }] -@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.350 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.354 = private constant [5 x i8] c"next\00" -@fld.str.355 = private constant [4 x i8] c"cap\00" -@field_names.356 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 4 }, { ptr, i64 } { ptr @fld.str.355, i64 3 }] -@str.357 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.358 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.361 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.362 = private constant [4 x i8] c"ctx\00" -@fld.str.363 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.364 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.365 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.362, i64 3 }, { ptr, i64 } { ptr @fld.str.363, i64 11 }, { ptr, i64 } { ptr @fld.str.364, i64 13 }] -@str.366 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.367 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.368 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.369 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.371 = private constant [6 x i8] c"first\00" -@fld.str.372 = private constant [10 x i8] c"end_index\00" -@fld.str.373 = private constant [7 x i8] c"parent\00" -@field_names.374 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.371, i64 5 }, { ptr, i64 } { ptr @fld.str.372, i64 9 }, { ptr, i64 } { ptr @fld.str.373, i64 6 }] -@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.376 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.380 = private constant [4 x i8] c"buf\00" -@fld.str.381 = private constant [4 x i8] c"len\00" -@fld.str.382 = private constant [4 x i8] c"pos\00" -@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 3 }, { ptr, i64 } { ptr @fld.str.381, i64 3 }, { ptr, i64 } { ptr @fld.str.382, i64 3 }] -@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.385 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.389 = private constant [7 x i8] c"parent\00" -@fld.str.390 = private constant [12 x i8] c"alloc_count\00" -@fld.str.391 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.392 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.393 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 6 }, { ptr, i64 } { ptr @fld.str.390, i64 11 }, { ptr, i64 } { ptr @fld.str.391, i64 13 }, { ptr, i64 } { ptr @fld.str.392, i64 17 }] -@str.394 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.395 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.396 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.397 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.398 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.399 = private constant [10 x i8] c"allocator\00" -@fld.str.400 = private constant [5 x i8] c"data\00" -@field_names.401 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.399, i64 9 }, { ptr, i64 } { ptr @fld.str.400, i64 4 }] -@str.402 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.403 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.405 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.406 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.407 = private constant [3 x i8] c"fd\00" -@field_names.408 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.407, i64 2 }] -@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.410 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.414 = private constant [5 x i8] c"file\00" -@fld.str.415 = private constant [5 x i8] c"line\00" -@fld.str.416 = private constant [4 x i8] c"col\00" -@fld.str.417 = private constant [5 x i8] c"func\00" -@fld.str.418 = private constant [10 x i8] c"line_text\00" -@field_names.419 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 4 }, { ptr, i64 } { ptr @fld.str.415, i64 4 }, { ptr, i64 } { ptr @fld.str.416, i64 3 }, { ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 9 }] -@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.421 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.422 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.423 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.424 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.425 = private constant [10 x i8] c"exit_code\00" -@fld.str.426 = private constant [7 x i8] c"stdout\00" -@field_names.427 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 9 }, { ptr, i64 } { ptr @fld.str.426, i64 6 }] -@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.429 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.431 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.432 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.433 = private constant [8 x i8] c"sin_len\00" -@fld.str.434 = private constant [11 x i8] c"sin_family\00" -@fld.str.435 = private constant [9 x i8] c"sin_port\00" -@fld.str.436 = private constant [9 x i8] c"sin_addr\00" -@fld.str.437 = private constant [9 x i8] c"sin_zero\00" -@field_names.438 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 7 }, { ptr, i64 } { ptr @fld.str.434, i64 10 }, { ptr, i64 } { ptr @fld.str.435, i64 8 }, { ptr, i64 } { ptr @fld.str.436, i64 8 }, { ptr, i64 } { ptr @fld.str.437, i64 8 }] -@str.439 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.440 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.441 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.442 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.443 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.444 = private constant [6 x i8] c"items\00" -@fld.str.445 = private constant [4 x i8] c"len\00" -@fld.str.446 = private constant [4 x i8] c"cap\00" -@field_names.447 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.444, i64 5 }, { ptr, i64 } { ptr @fld.str.445, i64 3 }, { ptr, i64 } { ptr @fld.str.446, i64 3 }] -@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.449 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.453 = private constant [6 x i8] c"items\00" -@fld.str.454 = private constant [4 x i8] c"len\00" -@fld.str.455 = private constant [4 x i8] c"cap\00" -@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] -@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.458 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.462 = private constant [4 x i8] c"key\00" -@fld.str.463 = private constant [4 x i8] c"val\00" -@field_names.464 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 3 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }] -@str.465 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.466 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.467 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.469 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.470 = private constant [4 x i8] c"dst\00" -@fld.str.471 = private constant [4 x i8] c"pos\00" -@fld.str.472 = private constant [5 x i8] c"file\00" -@field_names.473 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.470, i64 3 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 4 }] -@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.475 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.479 = private constant [4 x i8] c"src\00" -@fld.str.480 = private constant [4 x i8] c"pos\00" -@fld.str.481 = private constant [6 x i8] c"alloc\00" -@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 5 }] -@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.484 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.488 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.490 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.494 = private constant [5 x i8] c"name\00" -@fld.str.495 = private constant [12 x i8] c"takes_value\00" -@fld.str.496 = private constant [9 x i8] c"required\00" -@field_names.497 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.494, i64 4 }, { ptr, i64 } { ptr @fld.str.495, i64 11 }, { ptr, i64 } { ptr @fld.str.496, i64 8 }] -@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.499 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.503 = private constant [6 x i8] c"group\00" -@fld.str.504 = private constant [8 x i8] c"command\00" -@fld.str.505 = private constant [6 x i8] c"flags\00" -@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 5 }, { ptr, i64 } { ptr @fld.str.504, i64 7 }, { ptr, i64 } { ptr @fld.str.505, i64 5 }] -@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.508 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.512 = private constant [4 x i8] c"set\00" -@fld.str.513 = private constant [6 x i8] c"value\00" -@field_names.514 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 3 }, { ptr, i64 } { ptr @fld.str.513, i64 5 }] -@str.515 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.516 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.517 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.519 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.520 = private constant [6 x i8] c"index\00" -@fld.str.521 = private constant [6 x i8] c"token\00" -@field_names.522 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.520, i64 5 }, { ptr, i64 } { ptr @fld.str.521, i64 5 }] -@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.524 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.525 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.526 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.527 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.528 = private constant [6 x i8] c"group\00" -@fld.str.529 = private constant [8 x i8] c"command\00" -@fld.str.530 = private constant [10 x i8] c"cmd_index\00" -@fld.str.531 = private constant [5 x i8] c"json\00" -@fld.str.532 = private constant [5 x i8] c"rest\00" -@fld.str.533 = private constant [5 x i8] c"spec\00" -@fld.str.534 = private constant [7 x i8] c"values\00" -@field_names.535 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.528, i64 5 }, { ptr, i64 } { ptr @fld.str.529, i64 7 }, { ptr, i64 } { ptr @fld.str.530, i64 9 }, { ptr, i64 } { ptr @fld.str.531, i64 4 }, { ptr, i64 } { ptr @fld.str.532, i64 4 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }, { ptr, i64 } { ptr @fld.str.534, i64 6 }] -@str.536 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.537 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.540 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.541 = private constant [2 x i8] c"h\00" -@fld.str.542 = private constant [4 x i8] c"buf\00" -@fld.str.543 = private constant [8 x i8] c"buf_len\00" -@fld.str.544 = private constant [10 x i8] c"total_len\00" -@field_names.545 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.541, i64 1 }, { ptr, i64 } { ptr @fld.str.542, i64 3 }, { ptr, i64 } { ptr @fld.str.543, i64 7 }, { ptr, i64 } { ptr @fld.str.544, i64 9 }] -@str.546 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.548 = private constant [5 x i8] c"read\00" -@fld.str.549 = private constant [6 x i8] c"write\00" -@fld.str.550 = private constant [7 x i8] c"append\00" -@fld.str.551 = private constant [11 x i8] c"read_write\00" -@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 4 }, { ptr, i64 } { ptr @fld.str.549, i64 5 }, { ptr, i64 } { ptr @fld.str.550, i64 6 }, { ptr, i64 } { ptr @fld.str.551, i64 10 }] -@str.553 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.555 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.556 = private constant [4 x i8] c"set\00" -@fld.str.557 = private constant [8 x i8] c"current\00" -@fld.str.558 = private constant [4 x i8] c"end\00" -@field_names.559 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 3 }] -@str.560 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.563 = private constant [6 x i8] c"null_\00" -@fld.str.564 = private constant [6 x i8] c"bool_\00" -@fld.str.565 = private constant [5 x i8] c"int_\00" -@fld.str.566 = private constant [4 x i8] c"str\00" -@fld.str.567 = private constant [6 x i8] c"array\00" -@fld.str.568 = private constant [7 x i8] c"object\00" -@field_names.569 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 4 }, { ptr, i64 } { ptr @fld.str.566, i64 3 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 6 }] -@str.570 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.571 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.572 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.573 = private constant [6 x i8] c"macos\00" -@fld.str.574 = private constant [6 x i8] c"linux\00" -@fld.str.575 = private constant [8 x i8] c"windows\00" -@fld.str.576 = private constant [5 x i8] c"wasm\00" -@fld.str.577 = private constant [4 x i8] c"ios\00" -@fld.str.578 = private constant [8 x i8] c"android\00" -@fld.str.579 = private constant [8 x i8] c"unknown\00" -@field_names.580 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 7 }, { ptr, i64 } { ptr @fld.str.576, i64 4 }, { ptr, i64 } { ptr @fld.str.577, i64 3 }, { ptr, i64 } { ptr @fld.str.578, i64 7 }, { ptr, i64 } { ptr @fld.str.579, i64 7 }] -@str.581 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.582 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.584 = private constant [8 x i8] c"aarch64\00" -@fld.str.585 = private constant [7 x i8] c"x86_64\00" -@fld.str.586 = private constant [7 x i8] c"wasm32\00" -@fld.str.587 = private constant [7 x i8] c"wasm64\00" -@fld.str.588 = private constant [8 x i8] c"unknown\00" -@field_names.589 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 6 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] -@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.592 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.593 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.594 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.595 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.597 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.625 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.626 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.627 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.628 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.629 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.630 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.631 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.632 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.633 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.635 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.638 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.641 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.644 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.647 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.650 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.653 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.656 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.659 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.665 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.668 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.671 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.674 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.677 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.680 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.686 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.689 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.692 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.335 = private constant [5 x i8] c"line\00" +@fld.str.336 = private constant [4 x i8] c"col\00" +@fld.str.337 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.335, i64 4 }, { ptr, i64 } { ptr @fld.str.336, i64 3 }, { ptr, i64 } { ptr @fld.str.337, i64 4 }] +@str.338 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.339 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.340 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.341 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.342 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.343 = private constant [4 x i8] c"ctx\00" +@fld.str.344 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.345 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.346 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 11 }, { ptr, i64 } { ptr @fld.str.345, i64 13 }] +@str.347 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.348 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.349 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.350 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.351 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.352 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.353 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.354 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.357 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.358 = private constant [12 x i8] c"alloc_count\00" +@field_names.359 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.358, i64 11 }] +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [5 x i8] c"next\00" +@fld.str.366 = private constant [4 x i8] c"cap\00" +@field_names.367 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 4 }, { ptr, i64 } { ptr @fld.str.366, i64 3 }] +@str.368 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.369 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.372 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.373 = private constant [6 x i8] c"first\00" +@fld.str.374 = private constant [10 x i8] c"end_index\00" +@fld.str.375 = private constant [7 x i8] c"parent\00" +@field_names.376 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.373, i64 5 }, { ptr, i64 } { ptr @fld.str.374, i64 9 }, { ptr, i64 } { ptr @fld.str.375, i64 6 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.379 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.380 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.381 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.382 = private constant [4 x i8] c"buf\00" +@fld.str.383 = private constant [4 x i8] c"len\00" +@fld.str.384 = private constant [4 x i8] c"pos\00" +@field_names.385 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 3 }, { ptr, i64 } { ptr @fld.str.383, i64 3 }, { ptr, i64 } { ptr @fld.str.384, i64 3 }] +@str.386 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.387 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.388 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.389 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.390 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.391 = private constant [7 x i8] c"parent\00" +@fld.str.392 = private constant [12 x i8] c"alloc_count\00" +@fld.str.393 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.394 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.395 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.391, i64 6 }, { ptr, i64 } { ptr @fld.str.392, i64 11 }, { ptr, i64 } { ptr @fld.str.393, i64 13 }, { ptr, i64 } { ptr @fld.str.394, i64 17 }] +@str.396 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.397 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.398 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.399 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.400 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.401 = private constant [10 x i8] c"allocator\00" +@fld.str.402 = private constant [5 x i8] c"data\00" +@field_names.403 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.401, i64 9 }, { ptr, i64 } { ptr @fld.str.402, i64 4 }] +@str.404 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.405 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.407 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.408 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.409 = private constant [3 x i8] c"fd\00" +@field_names.410 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.409, i64 2 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [5 x i8] c"file\00" +@fld.str.417 = private constant [5 x i8] c"line\00" +@fld.str.418 = private constant [4 x i8] c"col\00" +@fld.str.419 = private constant [5 x i8] c"func\00" +@fld.str.420 = private constant [10 x i8] c"line_text\00" +@field_names.421 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 4 }, { ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 3 }, { ptr, i64 } { ptr @fld.str.419, i64 4 }, { ptr, i64 } { ptr @fld.str.420, i64 9 }] +@str.422 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.423 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.424 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.425 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.426 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.427 = private constant [10 x i8] c"exit_code\00" +@fld.str.428 = private constant [7 x i8] c"stdout\00" +@field_names.429 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.427, i64 9 }, { ptr, i64 } { ptr @fld.str.428, i64 6 }] +@str.430 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.431 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.433 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.434 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.435 = private constant [8 x i8] c"sin_len\00" +@fld.str.436 = private constant [11 x i8] c"sin_family\00" +@fld.str.437 = private constant [9 x i8] c"sin_port\00" +@fld.str.438 = private constant [9 x i8] c"sin_addr\00" +@fld.str.439 = private constant [9 x i8] c"sin_zero\00" +@field_names.440 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.435, i64 7 }, { ptr, i64 } { ptr @fld.str.436, i64 10 }, { ptr, i64 } { ptr @fld.str.437, i64 8 }, { ptr, i64 } { ptr @fld.str.438, i64 8 }, { ptr, i64 } { ptr @fld.str.439, i64 8 }] +@str.441 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.442 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.443 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.444 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.445 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.446 = private constant [6 x i8] c"items\00" +@fld.str.447 = private constant [4 x i8] c"len\00" +@fld.str.448 = private constant [4 x i8] c"cap\00" +@field_names.449 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.446, i64 5 }, { ptr, i64 } { ptr @fld.str.447, i64 3 }, { ptr, i64 } { ptr @fld.str.448, i64 3 }] +@str.450 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.451 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.452 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.454 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.455 = private constant [6 x i8] c"items\00" +@fld.str.456 = private constant [4 x i8] c"len\00" +@fld.str.457 = private constant [4 x i8] c"cap\00" +@field_names.458 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.455, i64 5 }, { ptr, i64 } { ptr @fld.str.456, i64 3 }, { ptr, i64 } { ptr @fld.str.457, i64 3 }] +@str.459 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.460 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.461 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.462 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.463 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.464 = private constant [4 x i8] c"key\00" +@fld.str.465 = private constant [4 x i8] c"val\00" +@field_names.466 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.464, i64 3 }, { ptr, i64 } { ptr @fld.str.465, i64 3 }] +@str.467 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.468 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.469 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.471 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.472 = private constant [4 x i8] c"dst\00" +@fld.str.473 = private constant [4 x i8] c"pos\00" +@fld.str.474 = private constant [5 x i8] c"file\00" +@field_names.475 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 3 }, { ptr, i64 } { ptr @fld.str.474, i64 4 }] +@str.476 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.477 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.478 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.479 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.480 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.481 = private constant [4 x i8] c"src\00" +@fld.str.482 = private constant [4 x i8] c"pos\00" +@fld.str.483 = private constant [6 x i8] c"alloc\00" +@field_names.484 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.481, i64 3 }, { ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 5 }] +@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.486 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.487 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.488 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.489 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.490 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.491 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.492 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.495 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.496 = private constant [5 x i8] c"name\00" +@fld.str.497 = private constant [12 x i8] c"takes_value\00" +@fld.str.498 = private constant [9 x i8] c"required\00" +@field_names.499 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.496, i64 4 }, { ptr, i64 } { ptr @fld.str.497, i64 11 }, { ptr, i64 } { ptr @fld.str.498, i64 8 }] +@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.501 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.504 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.505 = private constant [6 x i8] c"group\00" +@fld.str.506 = private constant [8 x i8] c"command\00" +@fld.str.507 = private constant [6 x i8] c"flags\00" +@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 5 }, { ptr, i64 } { ptr @fld.str.506, i64 7 }, { ptr, i64 } { ptr @fld.str.507, i64 5 }] +@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.510 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.514 = private constant [4 x i8] c"set\00" +@fld.str.515 = private constant [6 x i8] c"value\00" +@field_names.516 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 3 }, { ptr, i64 } { ptr @fld.str.515, i64 5 }] +@str.517 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.518 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.519 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.521 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.522 = private constant [6 x i8] c"index\00" +@fld.str.523 = private constant [6 x i8] c"token\00" +@field_names.524 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.522, i64 5 }, { ptr, i64 } { ptr @fld.str.523, i64 5 }] +@str.525 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.526 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.527 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.528 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.529 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.530 = private constant [6 x i8] c"group\00" +@fld.str.531 = private constant [8 x i8] c"command\00" +@fld.str.532 = private constant [10 x i8] c"cmd_index\00" +@fld.str.533 = private constant [5 x i8] c"json\00" +@fld.str.534 = private constant [5 x i8] c"rest\00" +@fld.str.535 = private constant [5 x i8] c"spec\00" +@fld.str.536 = private constant [7 x i8] c"values\00" +@field_names.537 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 5 }, { ptr, i64 } { ptr @fld.str.531, i64 7 }, { ptr, i64 } { ptr @fld.str.532, i64 9 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }, { ptr, i64 } { ptr @fld.str.534, i64 4 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }, { ptr, i64 } { ptr @fld.str.536, i64 6 }] +@str.538 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.539 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.542 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.543 = private constant [2 x i8] c"h\00" +@fld.str.544 = private constant [4 x i8] c"buf\00" +@fld.str.545 = private constant [8 x i8] c"buf_len\00" +@fld.str.546 = private constant [10 x i8] c"total_len\00" +@field_names.547 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.543, i64 1 }, { ptr, i64 } { ptr @fld.str.544, i64 3 }, { ptr, i64 } { ptr @fld.str.545, i64 7 }, { ptr, i64 } { ptr @fld.str.546, i64 9 }] +@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.550 = private constant [5 x i8] c"read\00" +@fld.str.551 = private constant [6 x i8] c"write\00" +@fld.str.552 = private constant [7 x i8] c"append\00" +@fld.str.553 = private constant [11 x i8] c"read_write\00" +@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 4 }, { ptr, i64 } { ptr @fld.str.551, i64 5 }, { ptr, i64 } { ptr @fld.str.552, i64 6 }, { ptr, i64 } { ptr @fld.str.553, i64 10 }] +@str.555 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.557 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.558 = private constant [4 x i8] c"set\00" +@fld.str.559 = private constant [8 x i8] c"current\00" +@fld.str.560 = private constant [4 x i8] c"end\00" +@field_names.561 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 3 }, { ptr, i64 } { ptr @fld.str.559, i64 7 }, { ptr, i64 } { ptr @fld.str.560, i64 3 }] +@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.565 = private constant [6 x i8] c"null_\00" +@fld.str.566 = private constant [6 x i8] c"bool_\00" +@fld.str.567 = private constant [5 x i8] c"int_\00" +@fld.str.568 = private constant [4 x i8] c"str\00" +@fld.str.569 = private constant [6 x i8] c"array\00" +@fld.str.570 = private constant [7 x i8] c"object\00" +@field_names.571 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 5 }, { ptr, i64 } { ptr @fld.str.567, i64 4 }, { ptr, i64 } { ptr @fld.str.568, i64 3 }, { ptr, i64 } { ptr @fld.str.569, i64 5 }, { ptr, i64 } { ptr @fld.str.570, i64 6 }] +@str.572 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.573 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.574 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.575 = private constant [6 x i8] c"macos\00" +@fld.str.576 = private constant [6 x i8] c"linux\00" +@fld.str.577 = private constant [8 x i8] c"windows\00" +@fld.str.578 = private constant [5 x i8] c"wasm\00" +@fld.str.579 = private constant [4 x i8] c"ios\00" +@fld.str.580 = private constant [8 x i8] c"android\00" +@fld.str.581 = private constant [8 x i8] c"unknown\00" +@field_names.582 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 7 }, { ptr, i64 } { ptr @fld.str.578, i64 4 }, { ptr, i64 } { ptr @fld.str.579, i64 3 }, { ptr, i64 } { ptr @fld.str.580, i64 7 }, { ptr, i64 } { ptr @fld.str.581, i64 7 }] +@str.583 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.584 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.586 = private constant [8 x i8] c"aarch64\00" +@fld.str.587 = private constant [7 x i8] c"x86_64\00" +@fld.str.588 = private constant [7 x i8] c"wasm32\00" +@fld.str.589 = private constant [7 x i8] c"wasm64\00" +@fld.str.590 = private constant [8 x i8] c"unknown\00" +@field_names.591 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.586, i64 7 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }, { ptr, i64 } { ptr @fld.str.588, i64 6 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }] +@str.592 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.594 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.595 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.596 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.597 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.599 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.602 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.603 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.605 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.627 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.628 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.629 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.630 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.631 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.632 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.633 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.634 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.635 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.636 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.637 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.638 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.640 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.643 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.646 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.649 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.652 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.655 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.658 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.661 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.667 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.670 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.673 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.676 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.679 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.682 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.688 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.691 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.694 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -617,6 +617,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -836,7 +839,7 @@ entry: br i1 %icmp, label %if.then.61, label %if.merge.62 if.then.61: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.62: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -963,7 +966,7 @@ if.else.84: ; preds = %entry br label %if.merge.85 if.merge.85: ; preds = %if.else.84, %if.then.83 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.83 ], [ { ptr @str.127, i64 5 }, %if.else.84 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.83 ], [ { ptr @str.129, i64 5 }, %if.else.84 ] ret { ptr, i64 } %bp } @@ -1297,7 +1300,7 @@ entry: br i1 %icmp, label %if.then.374, label %if.merge.375 if.then.374: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.375: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1447,7 +1450,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1473,9 +1476,9 @@ entry: i64 11, label %match.arm.47 i64 19, label %match.arm.48 i64 20, label %match.arm.48 - i64 22, label %match.arm.48 - i64 24, label %match.arm.48 - i64 26, label %match.arm.48 + i64 21, label %match.arm.48 + i64 23, label %match.arm.48 + i64 25, label %match.arm.48 i64 27, label %match.arm.48 i64 30, label %match.arm.48 i64 32, label %match.arm.48 @@ -1516,9 +1519,9 @@ entry: i64 85, label %match.arm.53 i64 97, label %match.arm.53 i64 18, label %match.arm.54 - i64 21, label %match.arm.54 - i64 23, label %match.arm.54 - i64 25, label %match.arm.54 + i64 22, label %match.arm.54 + i64 24, label %match.arm.54 + i64 26, label %match.arm.54 i64 28, label %match.arm.54 i64 29, label %match.arm.54 i64 31, label %match.arm.54 @@ -1558,7 +1561,7 @@ match.merge.42: ; preds = %dispatch.merge.477, ret { ptr, i64 } %loadN match.arm.43: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.42 match.arm.44: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1602,9 +1605,9 @@ match.arm.48: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.100 [ i64 19, label %dispatch.case.101 i64 20, label %dispatch.case.102 - i64 22, label %dispatch.case.103 - i64 24, label %dispatch.case.104 - i64 26, label %dispatch.case.105 + i64 21, label %dispatch.case.103 + i64 23, label %dispatch.case.104 + i64 25, label %dispatch.case.105 i64 27, label %dispatch.case.106 i64 30, label %dispatch.case.107 i64 32, label %dispatch.case.108 @@ -1685,9 +1688,9 @@ match.arm.54: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.339 [ i64 18, label %dispatch.case.340 - i64 21, label %dispatch.case.341 - i64 23, label %dispatch.case.342 - i64 25, label %dispatch.case.343 + i64 22, label %dispatch.case.341 + i64 24, label %dispatch.case.342 + i64 26, label %dispatch.case.343 i64 28, label %dispatch.case.344 i64 29, label %dispatch.case.345 i64 31, label %dispatch.case.346 @@ -1785,7 +1788,7 @@ dispatch.merge.99: ; preds = %dispatch.case.125, br label %match.merge.42 dispatch.default.100: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.304, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.101: ; preds = %match.arm.48 @@ -1799,32 +1802,32 @@ dispatch.case.101: ; preds = %match.arm.48 dispatch.case.102: ; preds = %match.arm.48 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.103: ; preds = %match.arm.48 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.104: ; preds = %match.arm.48 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.105: ; preds = %match.arm.48 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 @@ -1994,7 +1997,7 @@ dispatch.merge.251: ; preds = %dispatch.case.257, br label %match.merge.42 dispatch.default.252: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.251 dispatch.case.253: ; preds = %match.arm.49 @@ -2035,7 +2038,7 @@ dispatch.merge.268: ; preds = %dispatch.case.275, br label %match.merge.42 dispatch.default.269: ; preds = %match.arm.52 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.268 dispatch.case.270: ; preds = %match.arm.52 @@ -2092,7 +2095,7 @@ dispatch.merge.306: ; preds = %dispatch.case.312, br label %match.merge.42 dispatch.default.307: ; preds = %match.arm.53 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.306 dispatch.case.308: ; preds = %match.arm.53 @@ -2141,7 +2144,7 @@ dispatch.merge.338: ; preds = %dispatch.case.370, br label %match.merge.42 dispatch.default.339: ; preds = %match.arm.54 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.338 dispatch.case.340: ; preds = %match.arm.54 @@ -2367,7 +2370,7 @@ dispatch.merge.477: ; preds = %dispatch.case.482, br label %match.merge.42 dispatch.default.478: ; preds = %match.arm.55 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.477 dispatch.case.479: ; preds = %match.arm.55 @@ -2409,7 +2412,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.310, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2505,7 +2508,7 @@ if.merge.16: ; preds = %if.merge.30, %if.me if.then.17: ; preds = %if.then.14 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.311, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2513,7 +2516,7 @@ if.then.17: ; preds = %if.then.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2523,13 +2526,13 @@ if.then.17: ; preds = %if.then.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.18 if.merge.18: ; preds = %if.then.17, %if.then.14 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2537,7 +2540,7 @@ if.merge.18: ; preds = %if.then.17, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2551,7 +2554,7 @@ if.merge.18: ; preds = %if.then.17, %if.the if.then.28: ; preds = %if.else.15 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2559,7 +2562,7 @@ if.then.28: ; preds = %if.else.15 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2570,7 +2573,7 @@ if.then.28: ; preds = %if.else.15 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2627,7 +2630,7 @@ if.merge.36: ; preds = %if.merge.39, %if.el if.then.37: ; preds = %if.then.34 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2635,7 +2638,7 @@ if.then.37: ; preds = %if.then.34 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2646,7 +2649,7 @@ if.then.37: ; preds = %if.then.34 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2666,7 +2669,7 @@ if.merge.39: ; preds = %if.else.38, %if.the if.then.40: ; preds = %while.exit.7 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2674,7 +2677,7 @@ if.then.40: ; preds = %while.exit.7 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, 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 @@ -2685,7 +2688,7 @@ if.then.40: ; preds = %while.exit.7 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.41 @@ -2695,64 +2698,67 @@ if.merge.41: ; preds = %if.then.40, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2928,163 +2934,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3282,64 +3291,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3369,97 +3378,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3498,7 +3507,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3511,7 +3520,7 @@ entry: br i1 %icmp, label %if.then.0, label %if.merge.1 if.then.0: ; preds = %entry - %0 = call i64 @write(i32 1, ptr @str.325, i64 3) + %0 = call i64 @write(i32 1, ptr @str.327, i64 3) br label %if.merge.1 if.merge.1: ; preds = %if.then.0, %entry @@ -3552,7 +3561,7 @@ entry: define internal void @print__ct_sb195ea381495f949__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.326, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.328, i64 12 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3569,7 +3578,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 9) @@ -3598,7 +3607,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.328, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.330, i64 12 }) ret { ptr, i64 } %call } @@ -3609,7 +3618,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.329, i64 15 }, { ptr, i64 } { ptr @str.330, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.331, i64 15 }, { ptr, i64 } { ptr @str.332, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3628,12 +3637,12 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 @@ -3645,7 +3654,7 @@ if.merge.130: ; preds = %if.then.129, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3698,20 +3707,20 @@ fv.case24: ; preds = %if.merge.130 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.337, i64 10 }, { ptr, i64 } { ptr @str.338, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.339, i64 9 }, { ptr, i64 } { ptr @str.340, 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.131 -while.hdr.131: ; preds = %if.merge.135, %entry +while.hdr.131: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3721,224 +3730,24 @@ while.body.132: ; preds = %while.hdr.131 while.exit.133: ; preds = %while.hdr.131 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 1 }) ret { ptr, i64 } %callN if.then.134: ; preds = %while.body.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.135 if.merge.135: ; preds = %if.then.134, %while.body.132 %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.341, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.346, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 3 }, { ptr, i64 } { ptr @str.344, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.348, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 10 }, { ptr, i64 } { ptr @str.351, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.356, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.141 - -fv.default: ; preds = %if.merge.145 - br label %fv.merge - -fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.145 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.358, i64 9 }, { ptr, i64 } { ptr @str.359, 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.146 - -while.hdr.146: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.147, label %while.exit.148 - -while.body.147: ; preds = %while.hdr.146 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.149, label %if.merge.150 - -while.exit.148: ; preds = %while.hdr.146 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 1 }) - ret { ptr, i64 } %callN - -if.then.149: ; preds = %while.body.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.150 - -if.merge.150: ; preds = %if.then.149, %while.body.147 - %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.365, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, 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 @@ -3957,27 +3766,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.135 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.348, i64 10 }, { ptr, i64 } { ptr @str.349, 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.136 + +while.hdr.136: ; preds = %if.merge.140, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.352, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.354, i64 3 }, { ptr, i64 } { ptr @str.355, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.359, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.141 + +fv.default: ; preds = %if.merge.145 + br label %fv.merge + +fv.case: ; preds = %if.merge.145 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 10 }, { ptr, i64 } { ptr @str.362, 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.146 + +while.hdr.146: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.147, label %while.exit.148 + +while.body.147: ; preds = %while.hdr.146 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.149, label %if.merge.150 + +while.exit.148: ; preds = %while.hdr.146 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) + ret { ptr, i64 } %callN + +if.then.149: ; preds = %while.body.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.150 + +if.merge.150: ; preds = %if.then.149, %while.body.147 + %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.367, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.146 fv.default: ; preds = %if.merge.150 br label %fv.merge fv.case: ; preds = %if.merge.150 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.150 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -3987,7 +3996,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.367, i64 5 }, { ptr, i64 } { ptr @str.368, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.369, i64 5 }, { ptr, i64 } { ptr @str.370, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4006,24 +4015,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.374, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.376, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, 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 @@ -4050,7 +4059,7 @@ fv.default: ; preds = %if.merge.155 fv.case: ; preds = %if.merge.155 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 @@ -4062,7 +4071,7 @@ fv.case20: ; preds = %if.merge.155 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4071,7 +4080,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 8 }, { ptr, i64 } { ptr @str.377, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 8 }, { ptr, i64 } { ptr @str.379, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4090,24 +4099,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %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.383, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.385, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, 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 @@ -4154,7 +4163,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 17 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.387, i64 17 }, { ptr, i64 } { ptr @str.388, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4173,24 +4182,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.393, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.395, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4219,7 +4228,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4244,7 +4253,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.395, i64 7 }, { ptr, i64 } { ptr @str.396, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.397, i64 7 }, { ptr, i64 } { ptr @str.398, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4263,24 +4272,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.401, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.403, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, 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 @@ -4307,7 +4316,7 @@ fv.case: ; preds = %if.merge.170 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.170 @@ -4322,7 +4331,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.403, i64 4 }, { ptr, i64 } { ptr @str.404, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.405, i64 4 }, { ptr, i64 } { ptr @str.406, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4341,24 +4350,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.410, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4395,7 +4404,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 10 }, { ptr, i64 } { ptr @str.411, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 10 }, { ptr, i64 } { ptr @str.413, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4414,24 +4423,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.419, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.421, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4497,7 +4506,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 13 }, { ptr, i64 } { ptr @str.422, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.423, i64 13 }, { ptr, i64 } { ptr @str.424, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4516,24 +4525,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %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.427, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.429, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4575,7 +4584,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 8 }, { ptr, i64 } { ptr @str.430, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.431, i64 8 }, { ptr, i64 } { ptr @str.432, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4594,24 +4603,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.438, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.440, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4672,7 +4681,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.440, i64 5 }, { ptr, i64 } { ptr @str.441, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.442, i64 5 }, { ptr, i64 } { ptr @str.443, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4691,24 +4700,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.447, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.449, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, 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 @@ -4754,7 +4763,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 6 }, { ptr, i64 } { ptr @str.450, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.451, i64 6 }, { ptr, i64 } { ptr @str.452, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4773,24 +4782,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.456, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.458, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, 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 @@ -4838,7 +4847,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4857,24 +4866,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.464, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.466, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4918,7 +4927,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.466, i64 4 }, { ptr, i64 } { ptr @str.467, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.468, i64 4 }, { ptr, i64 } { ptr @str.469, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4937,24 +4946,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.473, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.475, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5004,7 +5013,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 6 }, { ptr, i64 } { ptr @str.476, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.477, i64 6 }, { ptr, i64 } { ptr @str.478, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5023,24 +5032,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.482, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.484, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5080,7 +5089,7 @@ fv.case20: ; preds = %if.merge.215 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5089,7 +5098,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 12 }, { ptr, i64 } { ptr @str.485, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 12 }, { ptr, i64 } { ptr @str.487, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5108,24 +5117,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.488, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.490, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5145,7 +5154,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 8 }, { ptr, i64 } { ptr @str.491, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5164,24 +5173,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.497, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.499, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5233,7 +5242,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 7 }, { ptr, i64 } { ptr @str.500, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 7 }, { ptr, i64 } { ptr @str.502, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5252,24 +5261,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.506, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.508, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5321,7 +5330,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 9 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 9 }, { ptr, i64 } { ptr @str.511, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5340,24 +5349,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.514, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.516, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5400,7 +5409,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.516, i64 4 }, { ptr, i64 } { ptr @str.517, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.518, i64 4 }, { ptr, i64 } { ptr @str.519, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5419,24 +5428,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %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.522, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.524, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5482,7 +5491,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 6 }, { ptr, i64 } { ptr @str.525, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 6 }, { ptr, i64 } { ptr @str.527, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5501,24 +5510,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.535, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.537, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5600,7 +5609,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.537, i64 6 }, { ptr, i64 } { ptr @str.538, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.539, i64 6 }, { ptr, i64 } { ptr @str.540, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5619,24 +5628,24 @@ while.body.247: ; preds = %while.hdr.246 while.exit.248: ; preds = %while.hdr.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 1 }) ret { ptr, i64 } %callN if.then.249: ; preds = %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.250 if.merge.250: ; preds = %if.then.249, %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.545, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.547, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5695,9 +5704,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.547, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, 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 @@ -5716,8 +5725,8 @@ entry: if.then.258: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.259 @@ -5736,9 +5745,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.557, 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 @@ -5757,8 +5766,8 @@ entry: if.then.260: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.261 @@ -5788,9 +5797,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.569, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.571, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5807,8 +5816,8 @@ entry: if.then.262: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.570, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.263 @@ -5886,9 +5895,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.582, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, 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 @@ -5907,8 +5916,8 @@ entry: if.then.264: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.265 @@ -5927,9 +5936,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.591, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, 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 @@ -5948,8 +5957,8 @@ entry: if.then.266: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.267 @@ -5966,7 +5975,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.592, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.594, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -5983,12 +5992,12 @@ while.body.277: ; preds = %while.hdr.276 while.exit.278: ; preds = %while.hdr.276 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 1 }) ret { ptr, i64 } %call if.then.279: ; preds = %while.body.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6017,7 +6026,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.595, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.597, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6034,12 +6043,12 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) ret { ptr, i64 } %call if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -6069,7 +6078,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.598, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.600, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6086,12 +6095,12 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 1 }) ret { ptr, i64 } %call if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6119,7 +6128,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.603, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6136,12 +6145,12 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 1 }) ret { ptr, i64 } %call if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -6170,7 +6179,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6187,12 +6196,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6221,7 +6230,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6238,12 +6247,12 @@ while.body.302: ; preds = %while.hdr.301 while.exit.303: ; preds = %while.hdr.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %call if.then.304: ; preds = %while.body.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 @@ -6273,7 +6282,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6292,12 +6301,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6326,7 +6335,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6345,12 +6354,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6379,7 +6388,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6398,12 +6407,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6433,7 +6442,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6452,12 +6461,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6487,7 +6496,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.333 @@ -6506,12 +6515,12 @@ while.body.334: ; preds = %while.hdr.333 while.exit.335: ; preds = %while.hdr.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %call if.then.336: ; preds = %while.body.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.337 @@ -6553,12 +6562,12 @@ if.then.371: ; preds = %entry if.else.372: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.627, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.626, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 5 }, { ptr, i64 } %callN) br label %if.merge.373 if.merge.373: ; preds = %if.else.372, %if.then.371 - %bp = phi { ptr, i64 } [ { ptr @str.625, i64 4 }, %if.then.371 ], [ %callN, %if.else.372 ] + %bp = phi { ptr, i64 } [ { ptr @str.627, i64 4 }, %if.then.371 ], [ %callN, %if.else.372 ] ret { ptr, i64 } %bp } @@ -6581,12 +6590,12 @@ if.then.387: ; preds = %entry if.else.388: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 11 }, { ptr, i64 } %callN) br label %if.merge.389 if.merge.389: ; preds = %if.else.388, %if.then.387 - %bp = phi { ptr, i64 } [ { ptr @str.628, i64 4 }, %if.then.387 ], [ %callN, %if.else.388 ] + %bp = phi { ptr, i64 } [ { ptr @str.630, i64 4 }, %if.then.387 ], [ %callN, %if.else.388 ] ret { ptr, i64 } %bp } @@ -6609,12 +6618,12 @@ if.then.390: ; preds = %entry if.else.391: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 4 }, { ptr, i64 } %callN) br label %if.merge.392 if.merge.392: ; preds = %if.else.391, %if.then.390 - %bp = phi { ptr, i64 } [ { ptr @str.631, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.633, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -6637,12 +6646,12 @@ if.then.393: ; preds = %entry if.else.394: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 11 }, { ptr, i64 } %callN) br label %if.merge.395 if.merge.395: ; preds = %if.else.394, %if.then.393 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] ret { ptr, i64 } %bp } @@ -6665,12 +6674,12 @@ if.then.396: ; preds = %entry if.else.397: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 6 }, { ptr, i64 } %callN) br label %if.merge.398 if.merge.398: ; preds = %if.else.397, %if.then.396 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6692,12 +6701,12 @@ if.then.399: ; preds = %entry if.else.400: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 5 }, { ptr, i64 } %callN) br label %if.merge.401 if.merge.401: ; preds = %if.else.400, %if.then.399 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] ret { ptr, i64 } %bp } @@ -6720,12 +6729,12 @@ if.then.402: ; preds = %entry if.else.403: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 9 }, { ptr, i64 } %callN) br label %if.merge.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6748,12 +6757,12 @@ if.then.405: ; preds = %entry if.else.406: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 18 }, { ptr, i64 } %callN) br label %if.merge.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -6776,12 +6785,12 @@ if.then.408: ; preds = %entry if.else.409: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 5 }, { ptr, i64 } %callN) br label %if.merge.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -6804,12 +6813,12 @@ if.then.411: ; preds = %entry if.else.412: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %callN) br label %if.merge.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -6832,12 +6841,12 @@ if.then.414: ; preds = %entry if.else.415: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 4 }, { ptr, i64 } %callN) br label %if.merge.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -6860,12 +6869,12 @@ if.then.417: ; preds = %entry if.else.418: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 9 }, { ptr, i64 } %callN) br label %if.merge.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -6888,12 +6897,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 4 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -6915,12 +6924,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 8 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -6943,12 +6952,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 6 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -6970,12 +6979,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 9 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -6998,12 +7007,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 7 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7026,12 +7035,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 5 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7054,12 +7063,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 7 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7082,12 +7091,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 4 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7110,12 +7119,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 7 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7138,12 +7147,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 5 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7166,12 +7175,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 7 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7194,12 +7203,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 12 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7222,12 +7231,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 6 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7250,12 +7259,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 4 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7278,12 +7287,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 7 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7306,12 +7315,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 4 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7334,12 +7343,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 7 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7362,12 +7371,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 6 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7390,12 +7399,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 5 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7411,7 +7420,7 @@ entry: br i1 %lnot, label %if.then.483, label %if.merge.484 if.then.483: ; preds = %entry - ret { ptr, i64 } { ptr @str.718, i64 4 } + ret { ptr, i64 } { ptr @str.720, i64 4 } if.merge.484: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7435,7 +7444,7 @@ entry: br i1 %lnot, label %if.then.485, label %if.merge.486 if.then.485: ; preds = %entry - ret { ptr, i64 } { ptr @str.719, i64 4 } + ret { ptr, i64 } { ptr @str.721, i64 4 } if.merge.486: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7459,7 +7468,7 @@ entry: br i1 %lnot, label %if.then.487, label %if.merge.488 if.then.487: ; preds = %entry - ret { ptr, i64 } { ptr @str.720, i64 4 } + ret { ptr, i64 } { ptr @str.722, i64 4 } if.merge.488: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7483,7 +7492,7 @@ entry: br i1 %lnot, label %if.then.489, label %if.merge.490 if.then.489: ; preds = %entry - ret { ptr, i64 } { ptr @str.721, i64 4 } + ret { ptr, i64 } { ptr @str.723, i64 4 } if.merge.490: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0200-generics-generic.ir b/examples/expected/0200-generics-generic.ir index 52b908e..aaa625d 100644 --- a/examples/expected/0200-generics-generic.ir +++ b/examples/expected/0200-generics-generic.ir @@ -1,611 +1,611 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [160 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [8 x i8] c"*string\00" -@tn.str.239 = private constant [6 x i8] c"[]Any\00" -@tn.str.240 = private constant [5 x i8] c"*Any\00" -@tn.str.241 = private constant [7 x i8] c"[1]Any\00" -@tn.str.242 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.243 = private constant [7 x i8] c"*[]Any\00" -@tn.str.244 = private constant [6 x i8] c"*bool\00" -@tn.str.245 = private constant [5 x i8] c"*f64\00" -@tn.str.246 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.247 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.248 = private constant [11 x i8] c"*Allocator\00" -@tn.str.249 = private constant [9 x i8] c"*Context\00" -@tn.str.250 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.251 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.252 = private constant [8 x i8] c"*Member\00" -@tn.str.253 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.254 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.255 = private constant [9 x i8] c"*Command\00" -@tn.str.256 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.257 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.258 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.259 = private constant [7 x i8] c"*Value\00" -@tn.str.260 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.261 = private constant [14 x i8] c"*Architecture\00" -@tn.str.262 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.263 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.264 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.265 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.266 = private constant [10 x i8] c"*[]string\00" -@tn.str.267 = private constant [6 x i8] c"*[]u8\00" -@tn.str.268 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.269 = private constant [11 x i8] c"*[]Command\00" -@tn.str.270 = private constant [6 x i8] c"**GPA\00" -@tn.str.271 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.272 = private constant [8 x i8] c"**Arena\00" -@tn.str.273 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.274 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.275 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.276 = private constant [7 x i8] c"**File\00" -@tn.str.277 = private constant [5 x i8] c"**u8\00" -@tn.str.278 = private constant [6 x i8] c"**s32\00" -@tn.str.279 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.280 = private constant [6 x i8] c"**u32\00" -@tn.str.281 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.282 = private constant [8 x i8] c"**Array\00" -@tn.str.283 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.284 = private constant [9 x i8] c"**Object\00" -@tn.str.285 = private constant [7 x i8] c"**Sink\00" -@tn.str.286 = private constant [9 x i8] c"**Parser\00" -@tn.str.287 = private constant [6 x i8] c"**s64\00" -@tn.str.288 = private constant [9 x i8] c"**Parsed\00" -@tn.str.289 = private constant [7 x i8] c"**Diag\00" -@tn.str.290 = private constant [9 x i8] c"**Sha256\00" -@tn.str.291 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.292 = private constant [8 x i8] c"***void\00" -@tn.str.293 = private constant [9 x i8] c"**string\00" -@tn.str.294 = private constant [6 x i8] c"**Any\00" -@tn.str.295 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.296 = private constant [8 x i8] c"**[]Any\00" -@tn.str.297 = private constant [7 x i8] c"**bool\00" -@tn.str.298 = private constant [6 x i8] c"**f64\00" -@tn.str.299 = private constant [7 x i8] c"*?File\00" -@tn.str.300 = private constant [9 x i8] c"*?string\00" -@tn.str.301 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.302 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [160 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 5 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 5 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 16 }, { ptr, i64 } { ptr @tn.str.248, i64 10 }, { ptr, i64 } { ptr @tn.str.249, i64 8 }, { ptr, i64 } { ptr @tn.str.250, i64 11 }, { ptr, i64 } { ptr @tn.str.251, i64 14 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 13 }, { ptr, i64 } { ptr @tn.str.254, i64 9 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 9 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 6 }, { ptr, i64 } { ptr @tn.str.260, i64 16 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 14 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 7 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 9 }, { ptr, i64 } { ptr @tn.str.267, i64 5 }, { ptr, i64 } { ptr @tn.str.268, i64 11 }, { ptr, i64 } { ptr @tn.str.269, i64 10 }, { ptr, i64 } { ptr @tn.str.270, i64 5 }, { ptr, i64 } { ptr @tn.str.271, i64 12 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 6 }, { ptr, i64 } { ptr @tn.str.274, i64 10 }, { ptr, i64 } { ptr @tn.str.275, i64 19 }, { ptr, i64 } { ptr @tn.str.276, i64 6 }, { ptr, i64 } { ptr @tn.str.277, i64 4 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 10 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 9 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 8 }, { ptr, i64 } { ptr @tn.str.285, i64 6 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 5 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 13 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 8 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 15 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }] -@str.303 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.304 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [8 x i8] c"*string\00" +@tn.str.241 = private constant [6 x i8] c"[]Any\00" +@tn.str.242 = private constant [5 x i8] c"*Any\00" +@tn.str.243 = private constant [7 x i8] c"[1]Any\00" +@tn.str.244 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.245 = private constant [7 x i8] c"*[]Any\00" +@tn.str.246 = private constant [6 x i8] c"*bool\00" +@tn.str.247 = private constant [5 x i8] c"*f64\00" +@tn.str.248 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.249 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.250 = private constant [11 x i8] c"*Allocator\00" +@tn.str.251 = private constant [9 x i8] c"*Context\00" +@tn.str.252 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.253 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.254 = private constant [8 x i8] c"*Member\00" +@tn.str.255 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.256 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.257 = private constant [9 x i8] c"*Command\00" +@tn.str.258 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.259 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.260 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.261 = private constant [7 x i8] c"*Value\00" +@tn.str.262 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.263 = private constant [14 x i8] c"*Architecture\00" +@tn.str.264 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.265 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.266 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.267 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.268 = private constant [10 x i8] c"*[]string\00" +@tn.str.269 = private constant [6 x i8] c"*[]u8\00" +@tn.str.270 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.271 = private constant [11 x i8] c"*[]Command\00" +@tn.str.272 = private constant [6 x i8] c"**GPA\00" +@tn.str.273 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.274 = private constant [8 x i8] c"**Arena\00" +@tn.str.275 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.276 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.277 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.278 = private constant [7 x i8] c"**File\00" +@tn.str.279 = private constant [5 x i8] c"**u8\00" +@tn.str.280 = private constant [6 x i8] c"**s32\00" +@tn.str.281 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.282 = private constant [6 x i8] c"**u32\00" +@tn.str.283 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.284 = private constant [8 x i8] c"**Array\00" +@tn.str.285 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.286 = private constant [9 x i8] c"**Object\00" +@tn.str.287 = private constant [7 x i8] c"**Sink\00" +@tn.str.288 = private constant [9 x i8] c"**Parser\00" +@tn.str.289 = private constant [6 x i8] c"**s64\00" +@tn.str.290 = private constant [9 x i8] c"**Parsed\00" +@tn.str.291 = private constant [7 x i8] c"**Diag\00" +@tn.str.292 = private constant [9 x i8] c"**Sha256\00" +@tn.str.293 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.294 = private constant [8 x i8] c"***void\00" +@tn.str.295 = private constant [9 x i8] c"**string\00" +@tn.str.296 = private constant [6 x i8] c"**Any\00" +@tn.str.297 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.298 = private constant [8 x i8] c"**[]Any\00" +@tn.str.299 = private constant [7 x i8] c"**bool\00" +@tn.str.300 = private constant [6 x i8] c"**f64\00" +@tn.str.301 = private constant [7 x i8] c"*?File\00" +@tn.str.302 = private constant [9 x i8] c"*?string\00" +@tn.str.303 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.304 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [160 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 5 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 4 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 16 }, { ptr, i64 } { ptr @tn.str.250, i64 10 }, { ptr, i64 } { ptr @tn.str.251, i64 8 }, { ptr, i64 } { ptr @tn.str.252, i64 11 }, { ptr, i64 } { ptr @tn.str.253, i64 14 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 13 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 6 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 5 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 12 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 19 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 4 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 10 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 13 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 15 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }] @str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.309 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.310 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.311 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.312 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.313 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.314 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.315 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.316 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.317 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.324 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 -@str.325 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.311 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.312 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.313 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.314 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.315 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.316 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.326 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 -@str.327 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 -@str.328 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.328 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 @str.329 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 -@str.330 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.331 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.332 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.333 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.331 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", align 1 +@str.332 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.333 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.334 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.335 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.334 = private constant [5 x i8] c"line\00" -@fld.str.335 = private constant [4 x i8] c"col\00" -@fld.str.336 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.334, i64 4 }, { ptr, i64 } { ptr @fld.str.335, i64 3 }, { ptr, i64 } { ptr @fld.str.336, i64 4 }] -@str.337 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.338 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.339 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.340 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.342 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.343 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.344 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.346 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.348 = private constant [12 x i8] c"alloc_count\00" -@field_names.349 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.348, i64 11 }] -@str.350 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.351 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.355 = private constant [5 x i8] c"next\00" -@fld.str.356 = private constant [4 x i8] c"cap\00" -@field_names.357 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.355, i64 4 }, { ptr, i64 } { ptr @fld.str.356, i64 3 }] -@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.359 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.361 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.363 = private constant [4 x i8] c"ctx\00" -@fld.str.364 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.365 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.366 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.363, i64 3 }, { ptr, i64 } { ptr @fld.str.364, i64 11 }, { ptr, i64 } { ptr @fld.str.365, i64 13 }] -@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.368 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.372 = private constant [6 x i8] c"first\00" -@fld.str.373 = private constant [10 x i8] c"end_index\00" -@fld.str.374 = private constant [7 x i8] c"parent\00" -@field_names.375 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 5 }, { ptr, i64 } { ptr @fld.str.373, i64 9 }, { ptr, i64 } { ptr @fld.str.374, i64 6 }] -@str.376 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.377 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.378 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.379 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.380 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.381 = private constant [4 x i8] c"buf\00" -@fld.str.382 = private constant [4 x i8] c"len\00" -@fld.str.383 = private constant [4 x i8] c"pos\00" -@field_names.384 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.381, i64 3 }, { ptr, i64 } { ptr @fld.str.382, i64 3 }, { ptr, i64 } { ptr @fld.str.383, i64 3 }] -@str.385 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.386 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.387 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.388 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.389 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.390 = private constant [7 x i8] c"parent\00" -@fld.str.391 = private constant [12 x i8] c"alloc_count\00" -@fld.str.392 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.393 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.394 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.390, i64 6 }, { ptr, i64 } { ptr @fld.str.391, i64 11 }, { ptr, i64 } { ptr @fld.str.392, i64 13 }, { ptr, i64 } { ptr @fld.str.393, i64 17 }] -@str.395 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.396 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.397 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.398 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.399 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.400 = private constant [10 x i8] c"allocator\00" -@fld.str.401 = private constant [5 x i8] c"data\00" -@field_names.402 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.400, i64 9 }, { ptr, i64 } { ptr @fld.str.401, i64 4 }] -@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.404 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.408 = private constant [3 x i8] c"fd\00" -@field_names.409 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 2 }] -@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.411 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.415 = private constant [5 x i8] c"file\00" -@fld.str.416 = private constant [5 x i8] c"line\00" -@fld.str.417 = private constant [4 x i8] c"col\00" -@fld.str.418 = private constant [5 x i8] c"func\00" -@fld.str.419 = private constant [10 x i8] c"line_text\00" -@field_names.420 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 4 }, { ptr, i64 } { ptr @fld.str.416, i64 4 }, { ptr, i64 } { ptr @fld.str.417, i64 3 }, { ptr, i64 } { ptr @fld.str.418, i64 4 }, { ptr, i64 } { ptr @fld.str.419, i64 9 }] -@str.421 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.422 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.423 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.424 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.425 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.426 = private constant [10 x i8] c"exit_code\00" -@fld.str.427 = private constant [7 x i8] c"stdout\00" -@field_names.428 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.426, i64 9 }, { ptr, i64 } { ptr @fld.str.427, i64 6 }] -@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.430 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.434 = private constant [8 x i8] c"sin_len\00" -@fld.str.435 = private constant [11 x i8] c"sin_family\00" -@fld.str.436 = private constant [9 x i8] c"sin_port\00" -@fld.str.437 = private constant [9 x i8] c"sin_addr\00" -@fld.str.438 = private constant [9 x i8] c"sin_zero\00" -@field_names.439 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 7 }, { ptr, i64 } { ptr @fld.str.435, i64 10 }, { ptr, i64 } { ptr @fld.str.436, i64 8 }, { ptr, i64 } { ptr @fld.str.437, i64 8 }, { ptr, i64 } { ptr @fld.str.438, i64 8 }] -@str.440 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.441 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.442 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.443 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.444 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.445 = private constant [6 x i8] c"items\00" -@fld.str.446 = private constant [4 x i8] c"len\00" -@fld.str.447 = private constant [4 x i8] c"cap\00" -@field_names.448 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.445, i64 5 }, { ptr, i64 } { ptr @fld.str.446, i64 3 }, { ptr, i64 } { ptr @fld.str.447, i64 3 }] -@str.449 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.450 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.452 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.453 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.454 = private constant [6 x i8] c"items\00" -@fld.str.455 = private constant [4 x i8] c"len\00" -@fld.str.456 = private constant [4 x i8] c"cap\00" -@field_names.457 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.454, i64 5 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }, { ptr, i64 } { ptr @fld.str.456, i64 3 }] -@str.458 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.459 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.460 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.461 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.462 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.463 = private constant [4 x i8] c"key\00" -@fld.str.464 = private constant [4 x i8] c"val\00" -@field_names.465 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.463, i64 3 }, { ptr, i64 } { ptr @fld.str.464, i64 3 }] -@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.467 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.469 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.470 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.471 = private constant [4 x i8] c"dst\00" -@fld.str.472 = private constant [4 x i8] c"pos\00" -@fld.str.473 = private constant [5 x i8] c"file\00" -@field_names.474 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 4 }] -@str.475 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.476 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.477 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.478 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.479 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.480 = private constant [4 x i8] c"src\00" -@fld.str.481 = private constant [4 x i8] c"pos\00" -@fld.str.482 = private constant [6 x i8] c"alloc\00" -@field_names.483 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 3 }, { ptr, i64 } { ptr @fld.str.482, i64 5 }] -@str.484 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.485 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.486 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.487 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.488 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.489 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.495 = private constant [5 x i8] c"name\00" -@fld.str.496 = private constant [12 x i8] c"takes_value\00" -@fld.str.497 = private constant [9 x i8] c"required\00" -@field_names.498 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.495, i64 4 }, { ptr, i64 } { ptr @fld.str.496, i64 11 }, { ptr, i64 } { ptr @fld.str.497, i64 8 }] -@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.500 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.502 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.503 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.504 = private constant [6 x i8] c"group\00" -@fld.str.505 = private constant [8 x i8] c"command\00" -@fld.str.506 = private constant [6 x i8] c"flags\00" -@field_names.507 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.504, i64 5 }, { ptr, i64 } { ptr @fld.str.505, i64 7 }, { ptr, i64 } { ptr @fld.str.506, i64 5 }] -@str.508 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.509 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.511 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.512 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.513 = private constant [4 x i8] c"set\00" -@fld.str.514 = private constant [6 x i8] c"value\00" -@field_names.515 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.513, i64 3 }, { ptr, i64 } { ptr @fld.str.514, i64 5 }] -@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.517 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.521 = private constant [6 x i8] c"index\00" -@fld.str.522 = private constant [6 x i8] c"token\00" -@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 5 }, { ptr, i64 } { ptr @fld.str.522, i64 5 }] -@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.525 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.529 = private constant [6 x i8] c"group\00" -@fld.str.530 = private constant [8 x i8] c"command\00" -@fld.str.531 = private constant [10 x i8] c"cmd_index\00" -@fld.str.532 = private constant [5 x i8] c"json\00" -@fld.str.533 = private constant [5 x i8] c"rest\00" -@fld.str.534 = private constant [5 x i8] c"spec\00" -@fld.str.535 = private constant [7 x i8] c"values\00" -@field_names.536 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 5 }, { ptr, i64 } { ptr @fld.str.530, i64 7 }, { ptr, i64 } { ptr @fld.str.531, i64 9 }, { ptr, i64 } { ptr @fld.str.532, i64 4 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }, { ptr, i64 } { ptr @fld.str.534, i64 4 }, { ptr, i64 } { ptr @fld.str.535, i64 6 }] -@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.538 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.542 = private constant [2 x i8] c"h\00" -@fld.str.543 = private constant [4 x i8] c"buf\00" -@fld.str.544 = private constant [8 x i8] c"buf_len\00" -@fld.str.545 = private constant [10 x i8] c"total_len\00" -@field_names.546 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 1 }, { ptr, i64 } { ptr @fld.str.543, i64 3 }, { ptr, i64 } { ptr @fld.str.544, i64 7 }, { ptr, i64 } { ptr @fld.str.545, i64 9 }] -@str.547 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.548 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.549 = private constant [5 x i8] c"read\00" -@fld.str.550 = private constant [6 x i8] c"write\00" -@fld.str.551 = private constant [7 x i8] c"append\00" -@fld.str.552 = private constant [11 x i8] c"read_write\00" -@field_names.553 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 5 }, { ptr, i64 } { ptr @fld.str.551, i64 6 }, { ptr, i64 } { ptr @fld.str.552, i64 10 }] -@str.554 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.555 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.556 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.557 = private constant [4 x i8] c"set\00" -@fld.str.558 = private constant [8 x i8] c"current\00" -@fld.str.559 = private constant [4 x i8] c"end\00" -@field_names.560 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 3 }, { ptr, i64 } { ptr @fld.str.558, i64 7 }, { ptr, i64 } { ptr @fld.str.559, i64 3 }] -@str.561 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.563 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.564 = private constant [6 x i8] c"null_\00" -@fld.str.565 = private constant [6 x i8] c"bool_\00" -@fld.str.566 = private constant [5 x i8] c"int_\00" -@fld.str.567 = private constant [4 x i8] c"str\00" -@fld.str.568 = private constant [6 x i8] c"array\00" -@fld.str.569 = private constant [7 x i8] c"object\00" -@field_names.570 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 4 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }, { ptr, i64 } { ptr @fld.str.568, i64 5 }, { ptr, i64 } { ptr @fld.str.569, i64 6 }] -@str.571 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.572 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.573 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.574 = private constant [6 x i8] c"macos\00" -@fld.str.575 = private constant [6 x i8] c"linux\00" -@fld.str.576 = private constant [8 x i8] c"windows\00" -@fld.str.577 = private constant [5 x i8] c"wasm\00" -@fld.str.578 = private constant [4 x i8] c"ios\00" -@fld.str.579 = private constant [8 x i8] c"android\00" -@fld.str.580 = private constant [8 x i8] c"unknown\00" -@field_names.581 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 7 }, { ptr, i64 } { ptr @fld.str.577, i64 4 }, { ptr, i64 } { ptr @fld.str.578, i64 3 }, { ptr, i64 } { ptr @fld.str.579, i64 7 }, { ptr, i64 } { ptr @fld.str.580, i64 7 }] -@str.582 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.585 = private constant [8 x i8] c"aarch64\00" -@fld.str.586 = private constant [7 x i8] c"x86_64\00" -@fld.str.587 = private constant [7 x i8] c"wasm32\00" -@fld.str.588 = private constant [7 x i8] c"wasm64\00" -@fld.str.589 = private constant [8 x i8] c"unknown\00" -@field_names.590 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }, { ptr, i64 } { ptr @fld.str.588, i64 6 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }] -@str.591 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.592 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.593 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.594 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.595 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.598 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.604 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.607 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.626 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.627 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.628 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.629 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.630 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.631 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.632 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.633 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.634 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.635 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.636 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.637 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.638 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.639 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.640 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.642 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.645 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.648 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.651 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.657 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.660 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.666 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.669 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.672 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.675 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.678 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.681 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.684 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.687 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.690 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.693 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.696 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.336 = private constant [5 x i8] c"line\00" +@fld.str.337 = private constant [4 x i8] c"col\00" +@fld.str.338 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.336, i64 4 }, { ptr, i64 } { ptr @fld.str.337, i64 3 }, { ptr, i64 } { ptr @fld.str.338, i64 4 }] +@str.339 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.340 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.341 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.342 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.343 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.344 = private constant [4 x i8] c"ctx\00" +@fld.str.345 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.346 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.347 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.344, i64 3 }, { ptr, i64 } { ptr @fld.str.345, i64 11 }, { ptr, i64 } { ptr @fld.str.346, i64 13 }] +@str.348 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.349 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.350 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.351 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.352 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.353 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.359 = private constant [12 x i8] c"alloc_count\00" +@field_names.360 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 11 }] +@str.361 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.362 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.364 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.366 = private constant [5 x i8] c"next\00" +@fld.str.367 = private constant [4 x i8] c"cap\00" +@field_names.368 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.366, i64 4 }, { ptr, i64 } { ptr @fld.str.367, i64 3 }] +@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.370 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.372 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.374 = private constant [6 x i8] c"first\00" +@fld.str.375 = private constant [10 x i8] c"end_index\00" +@fld.str.376 = private constant [7 x i8] c"parent\00" +@field_names.377 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 5 }, { ptr, i64 } { ptr @fld.str.375, i64 9 }, { ptr, i64 } { ptr @fld.str.376, i64 6 }] +@str.378 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.379 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.380 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.381 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.382 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.383 = private constant [4 x i8] c"buf\00" +@fld.str.384 = private constant [4 x i8] c"len\00" +@fld.str.385 = private constant [4 x i8] c"pos\00" +@field_names.386 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.383, i64 3 }, { ptr, i64 } { ptr @fld.str.384, i64 3 }, { ptr, i64 } { ptr @fld.str.385, i64 3 }] +@str.387 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.388 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.389 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.390 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.391 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.392 = private constant [7 x i8] c"parent\00" +@fld.str.393 = private constant [12 x i8] c"alloc_count\00" +@fld.str.394 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.395 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.396 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.392, i64 6 }, { ptr, i64 } { ptr @fld.str.393, i64 11 }, { ptr, i64 } { ptr @fld.str.394, i64 13 }, { ptr, i64 } { ptr @fld.str.395, i64 17 }] +@str.397 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.398 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.399 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.401 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.402 = private constant [10 x i8] c"allocator\00" +@fld.str.403 = private constant [5 x i8] c"data\00" +@field_names.404 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.402, i64 9 }, { ptr, i64 } { ptr @fld.str.403, i64 4 }] +@str.405 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.406 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.407 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.408 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.409 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.410 = private constant [3 x i8] c"fd\00" +@field_names.411 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.410, i64 2 }] +@str.412 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.413 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.415 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.416 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.417 = private constant [5 x i8] c"file\00" +@fld.str.418 = private constant [5 x i8] c"line\00" +@fld.str.419 = private constant [4 x i8] c"col\00" +@fld.str.420 = private constant [5 x i8] c"func\00" +@fld.str.421 = private constant [10 x i8] c"line_text\00" +@field_names.422 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 4 }, { ptr, i64 } { ptr @fld.str.419, i64 3 }, { ptr, i64 } { ptr @fld.str.420, i64 4 }, { ptr, i64 } { ptr @fld.str.421, i64 9 }] +@str.423 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.424 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.425 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.426 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.427 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.428 = private constant [10 x i8] c"exit_code\00" +@fld.str.429 = private constant [7 x i8] c"stdout\00" +@field_names.430 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.428, i64 9 }, { ptr, i64 } { ptr @fld.str.429, i64 6 }] +@str.431 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.432 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.433 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.434 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.435 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.436 = private constant [8 x i8] c"sin_len\00" +@fld.str.437 = private constant [11 x i8] c"sin_family\00" +@fld.str.438 = private constant [9 x i8] c"sin_port\00" +@fld.str.439 = private constant [9 x i8] c"sin_addr\00" +@fld.str.440 = private constant [9 x i8] c"sin_zero\00" +@field_names.441 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.436, i64 7 }, { ptr, i64 } { ptr @fld.str.437, i64 10 }, { ptr, i64 } { ptr @fld.str.438, i64 8 }, { ptr, i64 } { ptr @fld.str.439, i64 8 }, { ptr, i64 } { ptr @fld.str.440, i64 8 }] +@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.443 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.447 = private constant [6 x i8] c"items\00" +@fld.str.448 = private constant [4 x i8] c"len\00" +@fld.str.449 = private constant [4 x i8] c"cap\00" +@field_names.450 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 5 }, { ptr, i64 } { ptr @fld.str.448, i64 3 }, { ptr, i64 } { ptr @fld.str.449, i64 3 }] +@str.451 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.452 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.454 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.455 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.456 = private constant [6 x i8] c"items\00" +@fld.str.457 = private constant [4 x i8] c"len\00" +@fld.str.458 = private constant [4 x i8] c"cap\00" +@field_names.459 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.456, i64 5 }, { ptr, i64 } { ptr @fld.str.457, i64 3 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }] +@str.460 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.461 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.462 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.463 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.464 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.465 = private constant [4 x i8] c"key\00" +@fld.str.466 = private constant [4 x i8] c"val\00" +@field_names.467 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.465, i64 3 }, { ptr, i64 } { ptr @fld.str.466, i64 3 }] +@str.468 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.469 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.471 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.472 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.473 = private constant [4 x i8] c"dst\00" +@fld.str.474 = private constant [4 x i8] c"pos\00" +@fld.str.475 = private constant [5 x i8] c"file\00" +@field_names.476 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.473, i64 3 }, { ptr, i64 } { ptr @fld.str.474, i64 3 }, { ptr, i64 } { ptr @fld.str.475, i64 4 }] +@str.477 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.478 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.479 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.480 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.481 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.482 = private constant [4 x i8] c"src\00" +@fld.str.483 = private constant [4 x i8] c"pos\00" +@fld.str.484 = private constant [6 x i8] c"alloc\00" +@field_names.485 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 5 }] +@str.486 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.487 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.488 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.489 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.490 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.491 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.497 = private constant [5 x i8] c"name\00" +@fld.str.498 = private constant [12 x i8] c"takes_value\00" +@fld.str.499 = private constant [9 x i8] c"required\00" +@field_names.500 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.497, i64 4 }, { ptr, i64 } { ptr @fld.str.498, i64 11 }, { ptr, i64 } { ptr @fld.str.499, i64 8 }] +@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.502 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.504 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.505 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.506 = private constant [6 x i8] c"group\00" +@fld.str.507 = private constant [8 x i8] c"command\00" +@fld.str.508 = private constant [6 x i8] c"flags\00" +@field_names.509 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.506, i64 5 }, { ptr, i64 } { ptr @fld.str.507, i64 7 }, { ptr, i64 } { ptr @fld.str.508, i64 5 }] +@str.510 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.511 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.513 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.514 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.515 = private constant [4 x i8] c"set\00" +@fld.str.516 = private constant [6 x i8] c"value\00" +@field_names.517 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.515, i64 3 }, { ptr, i64 } { ptr @fld.str.516, i64 5 }] +@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.519 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.523 = private constant [6 x i8] c"index\00" +@fld.str.524 = private constant [6 x i8] c"token\00" +@field_names.525 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 5 }, { ptr, i64 } { ptr @fld.str.524, i64 5 }] +@str.526 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.527 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.528 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.529 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.530 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.531 = private constant [6 x i8] c"group\00" +@fld.str.532 = private constant [8 x i8] c"command\00" +@fld.str.533 = private constant [10 x i8] c"cmd_index\00" +@fld.str.534 = private constant [5 x i8] c"json\00" +@fld.str.535 = private constant [5 x i8] c"rest\00" +@fld.str.536 = private constant [5 x i8] c"spec\00" +@fld.str.537 = private constant [7 x i8] c"values\00" +@field_names.538 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.531, i64 5 }, { ptr, i64 } { ptr @fld.str.532, i64 7 }, { ptr, i64 } { ptr @fld.str.533, i64 9 }, { ptr, i64 } { ptr @fld.str.534, i64 4 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }, { ptr, i64 } { ptr @fld.str.536, i64 4 }, { ptr, i64 } { ptr @fld.str.537, i64 6 }] +@str.539 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.540 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.542 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.543 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.544 = private constant [2 x i8] c"h\00" +@fld.str.545 = private constant [4 x i8] c"buf\00" +@fld.str.546 = private constant [8 x i8] c"buf_len\00" +@fld.str.547 = private constant [10 x i8] c"total_len\00" +@field_names.548 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.544, i64 1 }, { ptr, i64 } { ptr @fld.str.545, i64 3 }, { ptr, i64 } { ptr @fld.str.546, i64 7 }, { ptr, i64 } { ptr @fld.str.547, i64 9 }] +@str.549 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.550 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.551 = private constant [5 x i8] c"read\00" +@fld.str.552 = private constant [6 x i8] c"write\00" +@fld.str.553 = private constant [7 x i8] c"append\00" +@fld.str.554 = private constant [11 x i8] c"read_write\00" +@field_names.555 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.551, i64 4 }, { ptr, i64 } { ptr @fld.str.552, i64 5 }, { ptr, i64 } { ptr @fld.str.553, i64 6 }, { ptr, i64 } { ptr @fld.str.554, i64 10 }] +@str.556 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.557 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.558 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.559 = private constant [4 x i8] c"set\00" +@fld.str.560 = private constant [8 x i8] c"current\00" +@fld.str.561 = private constant [4 x i8] c"end\00" +@field_names.562 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.559, i64 3 }, { ptr, i64 } { ptr @fld.str.560, i64 7 }, { ptr, i64 } { ptr @fld.str.561, i64 3 }] +@str.563 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.565 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.566 = private constant [6 x i8] c"null_\00" +@fld.str.567 = private constant [6 x i8] c"bool_\00" +@fld.str.568 = private constant [5 x i8] c"int_\00" +@fld.str.569 = private constant [4 x i8] c"str\00" +@fld.str.570 = private constant [6 x i8] c"array\00" +@fld.str.571 = private constant [7 x i8] c"object\00" +@field_names.572 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 5 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 4 }, { ptr, i64 } { ptr @fld.str.569, i64 3 }, { ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 6 }] +@str.573 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.574 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.575 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.576 = private constant [6 x i8] c"macos\00" +@fld.str.577 = private constant [6 x i8] c"linux\00" +@fld.str.578 = private constant [8 x i8] c"windows\00" +@fld.str.579 = private constant [5 x i8] c"wasm\00" +@fld.str.580 = private constant [4 x i8] c"ios\00" +@fld.str.581 = private constant [8 x i8] c"android\00" +@fld.str.582 = private constant [8 x i8] c"unknown\00" +@field_names.583 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 7 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 3 }, { ptr, i64 } { ptr @fld.str.581, i64 7 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }] +@str.584 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.587 = private constant [8 x i8] c"aarch64\00" +@fld.str.588 = private constant [7 x i8] c"x86_64\00" +@fld.str.589 = private constant [7 x i8] c"wasm32\00" +@fld.str.590 = private constant [7 x i8] c"wasm64\00" +@fld.str.591 = private constant [8 x i8] c"unknown\00" +@field_names.592 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 6 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }, { ptr, i64 } { ptr @fld.str.590, i64 6 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }] +@str.593 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.594 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.595 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.596 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.597 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.628 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.629 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.630 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.631 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.632 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.633 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.635 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.638 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.641 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.644 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.647 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.650 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.653 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.659 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.662 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.668 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.671 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.674 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.677 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.680 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.683 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.686 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.689 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.692 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.695 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.698 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -618,6 +618,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -837,7 +840,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -964,7 +967,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1298,7 +1301,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1448,7 +1451,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1474,9 +1477,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1517,9 +1520,9 @@ entry: i64 85, label %match.arm.48 i64 96, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1559,7 +1562,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1603,9 +1606,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1686,9 +1689,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.334 [ i64 18, label %dispatch.case.335 - i64 21, label %dispatch.case.336 - i64 23, label %dispatch.case.337 - i64 25, label %dispatch.case.338 + i64 22, label %dispatch.case.336 + i64 24, label %dispatch.case.337 + i64 26, label %dispatch.case.338 i64 28, label %dispatch.case.339 i64 29, label %dispatch.case.340 i64 31, label %dispatch.case.341 @@ -1786,7 +1789,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.303, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1800,32 +1803,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -1995,7 +1998,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.304, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2036,7 +2039,7 @@ dispatch.merge.263: ; preds = %dispatch.case.270, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2093,7 +2096,7 @@ dispatch.merge.301: ; preds = %dispatch.case.307, br label %match.merge.37 dispatch.default.302: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.301 dispatch.case.303: ; preds = %match.arm.48 @@ -2142,7 +2145,7 @@ dispatch.merge.333: ; preds = %dispatch.case.365, br label %match.merge.37 dispatch.default.334: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.49 @@ -2368,7 +2371,7 @@ dispatch.merge.472: ; preds = %dispatch.case.477, br label %match.merge.37 dispatch.default.473: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.472 dispatch.case.474: ; preds = %match.arm.50 @@ -2410,7 +2413,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.309, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2506,7 +2509,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.310, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2514,7 +2517,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.311, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2524,13 +2527,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2538,7 +2541,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2552,7 +2555,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2560,7 +2563,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2571,7 +2574,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2628,7 +2631,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2636,7 +2639,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2647,7 +2650,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2667,7 +2670,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2675,7 +2678,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, 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 @@ -2686,7 +2689,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2696,64 +2699,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2929,163 +2935,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3283,64 +3292,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3370,97 +3379,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3499,7 +3508,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3547,7 +3556,7 @@ entry: define internal void @print__ct_s95dfd2a009f17129__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.324, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.326, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3562,7 +3571,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -3589,7 +3598,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.326, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.328, i64 8 }) ret { ptr, i64 } %call } @@ -3610,7 +3619,7 @@ entry: define internal void @print__ct_s95dfd2a009f17129__pack_f64(ptr %0, double %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.327, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.329, i64 8 }, ptr %alloca, align 8 %allocaN = alloca double, align 8 store double %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3626,7 +3635,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -3654,7 +3663,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.329, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.331, i64 8 }) ret { ptr, i64 } %call } @@ -3665,7 +3674,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.330, i64 15 }, { ptr, i64 } { ptr @str.331, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.332, i64 15 }, { ptr, i64 } { ptr @str.333, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3684,12 +3693,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3701,7 +3710,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3754,20 +3763,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.338, i64 10 }, { ptr, i64 } { ptr @str.339, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.340, i64 9 }, { ptr, i64 } { ptr @str.341, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3777,224 +3786,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.342, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.347, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.344, i64 3 }, { ptr, i64 } { ptr @str.345, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.349, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 10 }, { ptr, i64 } { ptr @str.352, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.357, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.359, i64 9 }, { ptr, i64 } { ptr @str.360, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.366, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, 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 @@ -4013,27 +3822,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.349, i64 10 }, { ptr, i64 } { ptr @str.350, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.353, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 3 }, { ptr, i64 } { ptr @str.356, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.360, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.362, i64 10 }, { ptr, i64 } { ptr @str.363, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.368, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4043,7 +4052,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 5 }, { ptr, i64 } { ptr @str.369, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 5 }, { ptr, i64 } { ptr @str.371, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4062,24 +4071,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.375, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.377, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, 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 @@ -4106,7 +4115,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4118,7 +4127,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4127,7 +4136,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.377, i64 8 }, { ptr, i64 } { ptr @str.378, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 8 }, { ptr, i64 } { ptr @str.380, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4146,24 +4155,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.384, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.386, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, 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 @@ -4210,7 +4219,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.386, i64 17 }, { ptr, i64 } { ptr @str.387, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 17 }, { ptr, i64 } { ptr @str.389, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4229,24 +4238,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.394, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.396, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4275,7 +4284,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4300,7 +4309,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.396, i64 7 }, { ptr, i64 } { ptr @str.397, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 7 }, { ptr, i64 } { ptr @str.399, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4319,24 +4328,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.404, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, 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 @@ -4363,7 +4372,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4378,7 +4387,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 4 }, { ptr, i64 } { ptr @str.405, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.406, i64 4 }, { ptr, i64 } { ptr @str.407, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4397,24 +4406,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.409, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.411, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4451,7 +4460,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 10 }, { ptr, i64 } { ptr @str.412, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.413, i64 10 }, { ptr, i64 } { ptr @str.414, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4470,24 +4479,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.420, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.422, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4553,7 +4562,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.422, i64 13 }, { ptr, i64 } { ptr @str.423, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.424, i64 13 }, { ptr, i64 } { ptr @str.425, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4572,24 +4581,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.428, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.430, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4631,7 +4640,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 8 }, { ptr, i64 } { ptr @str.431, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.432, i64 8 }, { ptr, i64 } { ptr @str.433, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4650,24 +4659,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.439, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.441, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4728,7 +4737,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.441, i64 5 }, { ptr, i64 } { ptr @str.442, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 5 }, { ptr, i64 } { ptr @str.444, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4747,24 +4756,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.448, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.450, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, 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 @@ -4810,7 +4819,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.450, i64 6 }, { ptr, i64 } { ptr @str.451, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.452, i64 6 }, { ptr, i64 } { ptr @str.453, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4829,24 +4838,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.457, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.459, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, 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 @@ -4894,7 +4903,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.459, i64 6 }, { ptr, i64 } { ptr @str.460, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.461, i64 6 }, { ptr, i64 } { ptr @str.462, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4913,24 +4922,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.465, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.467, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4974,7 +4983,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 4 }, { ptr, i64 } { ptr @str.468, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.469, i64 4 }, { ptr, i64 } { ptr @str.470, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4993,24 +5002,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.474, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.476, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5060,7 +5069,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.476, i64 6 }, { ptr, i64 } { ptr @str.477, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.478, i64 6 }, { ptr, i64 } { ptr @str.479, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5079,24 +5088,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.483, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.485, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5136,7 +5145,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5145,7 +5154,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.485, i64 12 }, { ptr, i64 } { ptr @str.486, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.487, i64 12 }, { ptr, i64 } { ptr @str.488, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5164,24 +5173,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5201,7 +5210,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 8 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 8 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5220,24 +5229,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.498, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.500, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5289,7 +5298,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 7 }, { ptr, i64 } { ptr @str.501, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 7 }, { ptr, i64 } { ptr @str.503, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5308,24 +5317,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.507, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.509, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5377,7 +5386,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.509, i64 9 }, { ptr, i64 } { ptr @str.510, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.511, i64 9 }, { ptr, i64 } { ptr @str.512, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5396,24 +5405,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.515, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.517, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5456,7 +5465,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 4 }, { ptr, i64 } { ptr @str.518, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 4 }, { ptr, i64 } { ptr @str.520, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5475,24 +5484,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.523, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.525, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5538,7 +5547,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 6 }, { ptr, i64 } { ptr @str.526, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.527, i64 6 }, { ptr, i64 } { ptr @str.528, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5557,24 +5566,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.536, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.538, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5656,7 +5665,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 6 }, { ptr, i64 } { ptr @str.539, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5675,24 +5684,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.546, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.548, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5751,9 +5760,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.553, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.555, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.548, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.550, 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 @@ -5772,8 +5781,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5792,9 +5801,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.560, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.562, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, 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 @@ -5813,8 +5822,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.564, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5844,9 +5853,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.570, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.572, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.565, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5863,8 +5872,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.573, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -5942,9 +5951,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.581, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.573, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, 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 @@ -5963,8 +5972,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -5983,9 +5992,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.590, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.592, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, 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 @@ -6004,8 +6013,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.591, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.593, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6022,7 +6031,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.593, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.595, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.271 @@ -6039,12 +6048,12 @@ while.body.272: ; preds = %while.hdr.271 while.exit.273: ; preds = %while.hdr.271 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) ret { ptr, i64 } %call if.then.274: ; preds = %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.275 @@ -6073,7 +6082,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.596, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.598, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -6090,12 +6099,12 @@ while.body.277: ; preds = %while.hdr.276 while.exit.278: ; preds = %while.hdr.276 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) ret { ptr, i64 } %call if.then.279: ; preds = %while.body.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6125,7 +6134,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6142,12 +6151,12 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %call if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -6175,7 +6184,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6192,12 +6201,12 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) ret { ptr, i64 } %call if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6226,7 +6235,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6243,12 +6252,12 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) ret { ptr, i64 } %call if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -6277,7 +6286,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6294,12 +6303,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6329,7 +6338,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.308 @@ -6348,12 +6357,12 @@ while.body.309: ; preds = %while.hdr.308 while.exit.310: ; preds = %while.hdr.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) ret { ptr, i64 } %call if.then.311: ; preds = %while.body.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.312 @@ -6382,7 +6391,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6401,12 +6410,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6435,7 +6444,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6454,12 +6463,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6489,7 +6498,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6508,12 +6517,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6543,7 +6552,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6562,12 +6571,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6609,12 +6618,12 @@ if.then.366: ; preds = %entry if.else.367: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.627, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, i64 5 }, { ptr, i64 } %callN) br label %if.merge.368 if.merge.368: ; preds = %if.else.367, %if.then.366 - %bp = phi { ptr, i64 } [ { ptr @str.626, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.628, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6637,12 +6646,12 @@ if.then.382: ; preds = %entry if.else.383: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 11 }, { ptr, i64 } %callN) br label %if.merge.384 if.merge.384: ; preds = %if.else.383, %if.then.382 - %bp = phi { ptr, i64 } [ { ptr @str.629, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.631, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6665,12 +6674,12 @@ if.then.385: ; preds = %entry if.else.386: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 4 }, { ptr, i64 } %callN) br label %if.merge.387 if.merge.387: ; preds = %if.else.386, %if.then.385 - %bp = phi { ptr, i64 } [ { ptr @str.632, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6693,12 +6702,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6721,12 +6730,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 6 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6748,12 +6757,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 5 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6776,12 +6785,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 9 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6804,12 +6813,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 18 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6832,12 +6841,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 5 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6860,12 +6869,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6888,12 +6897,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 4 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6916,12 +6925,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 9 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6944,12 +6953,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6971,12 +6980,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 8 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6999,12 +7008,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 6 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7026,12 +7035,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 9 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7054,12 +7063,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 7 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7082,12 +7091,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 5 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7110,12 +7119,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7138,12 +7147,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 4 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7166,12 +7175,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7194,12 +7203,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 5 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7222,12 +7231,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7250,12 +7259,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 12 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7278,12 +7287,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 6 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7306,12 +7315,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 7 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7334,12 +7343,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 4 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7362,12 +7371,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 7 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7390,12 +7399,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 6 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7418,12 +7427,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 5 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7446,12 +7455,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 4 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7467,7 +7476,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.719, i64 4 } + ret { ptr, i64 } { ptr @str.721, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7491,7 +7500,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.720, i64 4 } + ret { ptr, i64 } { ptr @str.722, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7515,7 +7524,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.721, i64 4 } + ret { ptr, i64 } { ptr @str.723, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7539,7 +7548,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.722, i64 4 } + ret { ptr, i64 } { ptr @str.724, i64 4 } if.merge.485: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0201-generics-generic-struct.ir b/examples/expected/0201-generics-generic-struct.ir index 43b79f1..6ad259a 100644 --- a/examples/expected/0201-generics-generic-struct.ir +++ b/examples/expected/0201-generics-generic-struct.ir @@ -1,747 +1,747 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [187 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [8 x i8] c"[16]f32\00" -@tn.str.237 = private constant [5 x i8] c"Mat4\00" -@tn.str.238 = private constant [5 x i8] c"Vec2\00" -@tn.str.239 = private constant [14 x i8] c"Vector(3,f32)\00" -@tn.str.240 = private constant [12 x i8] c"Vec__3__f32\00" -@tn.str.241 = private constant [5 x i8] c"Vec3\00" -@tn.str.242 = private constant [13 x i8] c"Complex__u32\00" -@tn.str.243 = private constant [4 x i8] c"Foo\00" -@tn.str.244 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.245 = private constant [7 x i8] c"**void\00" -@tn.str.246 = private constant [6 x i8] c"*Vec3\00" -@tn.str.247 = private constant [8 x i8] c"*string\00" -@tn.str.248 = private constant [6 x i8] c"[]Any\00" -@tn.str.249 = private constant [5 x i8] c"*Any\00" -@tn.str.250 = private constant [7 x i8] c"[1]Any\00" -@tn.str.251 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.252 = private constant [7 x i8] c"*[]Any\00" -@tn.str.253 = private constant [6 x i8] c"*bool\00" -@tn.str.254 = private constant [5 x i8] c"*f32\00" -@tn.str.255 = private constant [15 x i8] c"*Vector(3,f32)\00" -@tn.str.256 = private constant [7 x i8] c"[5]f32\00" -@tn.str.257 = private constant [8 x i8] c"*[5]f32\00" -@tn.str.258 = private constant [5 x i8] c"*Foo\00" -@tn.str.259 = private constant [5 x i8] c"*f64\00" -@tn.str.260 = private constant [8 x i8] c"Sx__f32\00" -@tn.str.261 = private constant [9 x i8] c"*Sx__f32\00" -@tn.str.262 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.263 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.264 = private constant [11 x i8] c"*Allocator\00" -@tn.str.265 = private constant [9 x i8] c"*Context\00" -@tn.str.266 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.267 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.268 = private constant [8 x i8] c"*Member\00" -@tn.str.269 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.270 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.271 = private constant [9 x i8] c"*Command\00" -@tn.str.272 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.273 = private constant [6 x i8] c"*Mat4\00" -@tn.str.274 = private constant [6 x i8] c"*Vec2\00" -@tn.str.275 = private constant [13 x i8] c"*Vec__3__f32\00" -@tn.str.276 = private constant [14 x i8] c"*Complex__u32\00" -@tn.str.277 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.278 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.279 = private constant [7 x i8] c"*Value\00" -@tn.str.280 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.281 = private constant [14 x i8] c"*Architecture\00" -@tn.str.282 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.283 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.284 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.285 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.286 = private constant [9 x i8] c"*[16]f32\00" -@tn.str.287 = private constant [10 x i8] c"*[]string\00" -@tn.str.288 = private constant [6 x i8] c"*[]u8\00" -@tn.str.289 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.290 = private constant [11 x i8] c"*[]Command\00" -@tn.str.291 = private constant [6 x i8] c"**GPA\00" -@tn.str.292 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.293 = private constant [8 x i8] c"**Arena\00" -@tn.str.294 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.295 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.296 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.297 = private constant [7 x i8] c"**File\00" -@tn.str.298 = private constant [5 x i8] c"**u8\00" -@tn.str.299 = private constant [6 x i8] c"**s32\00" -@tn.str.300 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.301 = private constant [6 x i8] c"**u32\00" -@tn.str.302 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.303 = private constant [8 x i8] c"**Array\00" -@tn.str.304 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.305 = private constant [9 x i8] c"**Object\00" -@tn.str.306 = private constant [7 x i8] c"**Sink\00" -@tn.str.307 = private constant [9 x i8] c"**Parser\00" -@tn.str.308 = private constant [6 x i8] c"**s64\00" -@tn.str.309 = private constant [9 x i8] c"**Parsed\00" -@tn.str.310 = private constant [7 x i8] c"**Diag\00" -@tn.str.311 = private constant [9 x i8] c"**Sha256\00" -@tn.str.312 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.313 = private constant [8 x i8] c"***void\00" -@tn.str.314 = private constant [7 x i8] c"**Vec3\00" -@tn.str.315 = private constant [9 x i8] c"**string\00" -@tn.str.316 = private constant [6 x i8] c"**Any\00" -@tn.str.317 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.318 = private constant [8 x i8] c"**[]Any\00" -@tn.str.319 = private constant [7 x i8] c"**bool\00" -@tn.str.320 = private constant [6 x i8] c"**f32\00" -@tn.str.321 = private constant [16 x i8] c"**Vector(3,f32)\00" -@tn.str.322 = private constant [9 x i8] c"**[5]f32\00" -@tn.str.323 = private constant [6 x i8] c"**Foo\00" -@tn.str.324 = private constant [6 x i8] c"**f64\00" -@tn.str.325 = private constant [10 x i8] c"**Sx__f32\00" -@tn.str.326 = private constant [7 x i8] c"*?File\00" -@tn.str.327 = private constant [9 x i8] c"*?string\00" -@tn.str.328 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.329 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [187 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 4 }, { ptr, i64 } { ptr @tn.str.238, i64 4 }, { ptr, i64 } { ptr @tn.str.239, i64 13 }, { ptr, i64 } { ptr @tn.str.240, i64 11 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 12 }, { ptr, i64 } { ptr @tn.str.243, i64 3 }, { ptr, i64 } { ptr @tn.str.244, i64 12 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 4 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 5 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 6 }, { ptr, i64 } { ptr @tn.str.257, i64 7 }, { ptr, i64 } { ptr @tn.str.258, i64 4 }, { ptr, i64 } { ptr @tn.str.259, i64 4 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 16 }, { ptr, i64 } { ptr @tn.str.264, i64 10 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 11 }, { ptr, i64 } { ptr @tn.str.267, i64 14 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 13 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 10 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 13 }, { ptr, i64 } { ptr @tn.str.277, i64 9 }, { ptr, i64 } { ptr @tn.str.278, i64 9 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 16 }, { ptr, i64 } { ptr @tn.str.281, i64 13 }, { ptr, i64 } { ptr @tn.str.282, i64 14 }, { ptr, i64 } { ptr @tn.str.283, i64 7 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 8 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 11 }, { ptr, i64 } { ptr @tn.str.290, i64 10 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 12 }, { ptr, i64 } { ptr @tn.str.293, i64 7 }, { ptr, i64 } { ptr @tn.str.294, i64 6 }, { ptr, i64 } { ptr @tn.str.295, i64 10 }, { ptr, i64 } { ptr @tn.str.296, i64 19 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 4 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 10 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 9 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 10 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 8 }, { ptr, i64 } { ptr @tn.str.308, i64 5 }, { ptr, i64 } { ptr @tn.str.309, i64 8 }, { ptr, i64 } { ptr @tn.str.310, i64 6 }, { ptr, i64 } { ptr @tn.str.311, i64 8 }, { ptr, i64 } { ptr @tn.str.312, i64 13 }, { ptr, i64 } { ptr @tn.str.313, i64 7 }, { ptr, i64 } { ptr @tn.str.314, i64 6 }, { ptr, i64 } { ptr @tn.str.315, i64 8 }, { ptr, i64 } { ptr @tn.str.316, i64 5 }, { ptr, i64 } { ptr @tn.str.317, i64 8 }, { ptr, i64 } { ptr @tn.str.318, i64 7 }, { ptr, i64 } { ptr @tn.str.319, i64 6 }, { ptr, i64 } { ptr @tn.str.320, i64 5 }, { ptr, i64 } { ptr @tn.str.321, i64 15 }, { ptr, i64 } { ptr @tn.str.322, i64 8 }, { ptr, i64 } { ptr @tn.str.323, i64 5 }, { ptr, i64 } { ptr @tn.str.324, i64 5 }, { ptr, i64 } { ptr @tn.str.325, i64 9 }, { ptr, i64 } { ptr @tn.str.326, i64 6 }, { ptr, i64 } { ptr @tn.str.327, i64 8 }, { ptr, i64 } { ptr @tn.str.328, i64 15 }, { ptr, i64 } { ptr @tn.str.329, i64 8 }] -@str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.331 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [8 x i8] c"[16]f32\00" +@tn.str.239 = private constant [5 x i8] c"Mat4\00" +@tn.str.240 = private constant [5 x i8] c"Vec2\00" +@tn.str.241 = private constant [14 x i8] c"Vector(3,f32)\00" +@tn.str.242 = private constant [12 x i8] c"Vec__3__f32\00" +@tn.str.243 = private constant [5 x i8] c"Vec3\00" +@tn.str.244 = private constant [13 x i8] c"Complex__u32\00" +@tn.str.245 = private constant [4 x i8] c"Foo\00" +@tn.str.246 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.247 = private constant [7 x i8] c"**void\00" +@tn.str.248 = private constant [6 x i8] c"*Vec3\00" +@tn.str.249 = private constant [8 x i8] c"*string\00" +@tn.str.250 = private constant [6 x i8] c"[]Any\00" +@tn.str.251 = private constant [5 x i8] c"*Any\00" +@tn.str.252 = private constant [7 x i8] c"[1]Any\00" +@tn.str.253 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.254 = private constant [7 x i8] c"*[]Any\00" +@tn.str.255 = private constant [6 x i8] c"*bool\00" +@tn.str.256 = private constant [5 x i8] c"*f32\00" +@tn.str.257 = private constant [15 x i8] c"*Vector(3,f32)\00" +@tn.str.258 = private constant [7 x i8] c"[5]f32\00" +@tn.str.259 = private constant [8 x i8] c"*[5]f32\00" +@tn.str.260 = private constant [5 x i8] c"*Foo\00" +@tn.str.261 = private constant [5 x i8] c"*f64\00" +@tn.str.262 = private constant [8 x i8] c"Sx__f32\00" +@tn.str.263 = private constant [9 x i8] c"*Sx__f32\00" +@tn.str.264 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.265 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.266 = private constant [11 x i8] c"*Allocator\00" +@tn.str.267 = private constant [9 x i8] c"*Context\00" +@tn.str.268 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.269 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.270 = private constant [8 x i8] c"*Member\00" +@tn.str.271 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.272 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.273 = private constant [9 x i8] c"*Command\00" +@tn.str.274 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.275 = private constant [6 x i8] c"*Mat4\00" +@tn.str.276 = private constant [6 x i8] c"*Vec2\00" +@tn.str.277 = private constant [13 x i8] c"*Vec__3__f32\00" +@tn.str.278 = private constant [14 x i8] c"*Complex__u32\00" +@tn.str.279 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.280 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.281 = private constant [7 x i8] c"*Value\00" +@tn.str.282 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.283 = private constant [14 x i8] c"*Architecture\00" +@tn.str.284 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.285 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.286 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.287 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.288 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.289 = private constant [10 x i8] c"*[]string\00" +@tn.str.290 = private constant [6 x i8] c"*[]u8\00" +@tn.str.291 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.292 = private constant [11 x i8] c"*[]Command\00" +@tn.str.293 = private constant [6 x i8] c"**GPA\00" +@tn.str.294 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.295 = private constant [8 x i8] c"**Arena\00" +@tn.str.296 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.297 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.298 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.299 = private constant [7 x i8] c"**File\00" +@tn.str.300 = private constant [5 x i8] c"**u8\00" +@tn.str.301 = private constant [6 x i8] c"**s32\00" +@tn.str.302 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.303 = private constant [6 x i8] c"**u32\00" +@tn.str.304 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.305 = private constant [8 x i8] c"**Array\00" +@tn.str.306 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.307 = private constant [9 x i8] c"**Object\00" +@tn.str.308 = private constant [7 x i8] c"**Sink\00" +@tn.str.309 = private constant [9 x i8] c"**Parser\00" +@tn.str.310 = private constant [6 x i8] c"**s64\00" +@tn.str.311 = private constant [9 x i8] c"**Parsed\00" +@tn.str.312 = private constant [7 x i8] c"**Diag\00" +@tn.str.313 = private constant [9 x i8] c"**Sha256\00" +@tn.str.314 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.315 = private constant [8 x i8] c"***void\00" +@tn.str.316 = private constant [7 x i8] c"**Vec3\00" +@tn.str.317 = private constant [9 x i8] c"**string\00" +@tn.str.318 = private constant [6 x i8] c"**Any\00" +@tn.str.319 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.320 = private constant [8 x i8] c"**[]Any\00" +@tn.str.321 = private constant [7 x i8] c"**bool\00" +@tn.str.322 = private constant [6 x i8] c"**f32\00" +@tn.str.323 = private constant [16 x i8] c"**Vector(3,f32)\00" +@tn.str.324 = private constant [9 x i8] c"**[5]f32\00" +@tn.str.325 = private constant [6 x i8] c"**Foo\00" +@tn.str.326 = private constant [6 x i8] c"**f64\00" +@tn.str.327 = private constant [10 x i8] c"**Sx__f32\00" +@tn.str.328 = private constant [7 x i8] c"*?File\00" +@tn.str.329 = private constant [9 x i8] c"*?string\00" +@tn.str.330 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.331 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [187 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 4 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 13 }, { ptr, i64 } { ptr @tn.str.242, i64 11 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 12 }, { ptr, i64 } { ptr @tn.str.245, i64 3 }, { ptr, i64 } { ptr @tn.str.246, i64 12 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 4 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 6 }, { ptr, i64 } { ptr @tn.str.255, i64 5 }, { ptr, i64 } { ptr @tn.str.256, i64 4 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 6 }, { ptr, i64 } { ptr @tn.str.259, i64 7 }, { ptr, i64 } { ptr @tn.str.260, i64 4 }, { ptr, i64 } { ptr @tn.str.261, i64 4 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 8 }, { ptr, i64 } { ptr @tn.str.264, i64 7 }, { ptr, i64 } { ptr @tn.str.265, i64 16 }, { ptr, i64 } { ptr @tn.str.266, i64 10 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 11 }, { ptr, i64 } { ptr @tn.str.269, i64 14 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 13 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 10 }, { ptr, i64 } { ptr @tn.str.275, i64 5 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 13 }, { ptr, i64 } { ptr @tn.str.279, i64 9 }, { ptr, i64 } { ptr @tn.str.280, i64 9 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 16 }, { ptr, i64 } { ptr @tn.str.283, i64 13 }, { ptr, i64 } { ptr @tn.str.284, i64 14 }, { ptr, i64 } { ptr @tn.str.285, i64 7 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 8 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 9 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 11 }, { ptr, i64 } { ptr @tn.str.292, i64 10 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 12 }, { ptr, i64 } { ptr @tn.str.295, i64 7 }, { ptr, i64 } { ptr @tn.str.296, i64 6 }, { ptr, i64 } { ptr @tn.str.297, i64 10 }, { ptr, i64 } { ptr @tn.str.298, i64 19 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 4 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 10 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 9 }, { ptr, i64 } { ptr @tn.str.305, i64 7 }, { ptr, i64 } { ptr @tn.str.306, i64 10 }, { ptr, i64 } { ptr @tn.str.307, i64 8 }, { ptr, i64 } { ptr @tn.str.308, i64 6 }, { ptr, i64 } { ptr @tn.str.309, i64 8 }, { ptr, i64 } { ptr @tn.str.310, i64 5 }, { ptr, i64 } { ptr @tn.str.311, i64 8 }, { ptr, i64 } { ptr @tn.str.312, i64 6 }, { ptr, i64 } { ptr @tn.str.313, i64 8 }, { ptr, i64 } { ptr @tn.str.314, i64 13 }, { ptr, i64 } { ptr @tn.str.315, i64 7 }, { ptr, i64 } { ptr @tn.str.316, i64 6 }, { ptr, i64 } { ptr @tn.str.317, i64 8 }, { ptr, i64 } { ptr @tn.str.318, i64 5 }, { ptr, i64 } { ptr @tn.str.319, i64 8 }, { ptr, i64 } { ptr @tn.str.320, i64 7 }, { ptr, i64 } { ptr @tn.str.321, i64 6 }, { ptr, i64 } { ptr @tn.str.322, i64 5 }, { ptr, i64 } { ptr @tn.str.323, i64 15 }, { ptr, i64 } { ptr @tn.str.324, i64 8 }, { ptr, i64 } { ptr @tn.str.325, i64 5 }, { ptr, i64 } { ptr @tn.str.326, i64 5 }, { ptr, i64 } { ptr @tn.str.327, i64 9 }, { ptr, i64 } { ptr @tn.str.328, i64 6 }, { ptr, i64 } { ptr @tn.str.329, i64 8 }, { ptr, i64 } { ptr @tn.str.330, i64 15 }, { ptr, i64 } { ptr @tn.str.331, i64 8 }] @str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.333 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.335 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.337 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.338 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.340 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.341 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.342 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.343 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.344 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.345 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.346 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.348 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.349 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.350 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.351 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.352 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", align 1 -@str.353 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.337 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.338 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.340 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.342 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.343 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.344 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.345 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.347 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.348 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.349 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.350 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.351 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.352 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.353 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.354 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", align 1 -@str.355 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", align 1 -@str.356 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.355 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.356 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", align 1 @str.357 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", align 1 -@str.358 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", align 1 -@str.359 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.358 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.359 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", align 1 @str.360 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", align 1 -@str.361 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", align 1 -@str.362 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.361 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.362 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", align 1 @str.363 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", align 1 -@str.364 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", align 1 -@str.365 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.364 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.365 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", align 1 @str.366 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", align 1 -@str.367 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", align 1 -@str.368 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.367 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.368 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", align 1 @str.369 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", align 1 -@str.370 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", align 1 -@str.371 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.370 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.371 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", align 1 @str.372 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", align 1 -@str.373 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", align 1 -@str.374 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.373 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.374 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", align 1 @str.375 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", align 1 -@str.376 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", align 1 -@str.377 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.376 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.377 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", align 1 @str.378 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", align 1 -@str.379 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", align 1 -@str.380 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.379 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.380 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", align 1 @str.381 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", align 1 -@str.382 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.383 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.382 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.383 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", align 1 @str.384 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.385 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.386 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.385 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.386 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 @str.387 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.388 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.389 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.390 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.391 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.388 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.389 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.390 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.392 = private constant [5 x i8] c"line\00" -@fld.str.393 = private constant [4 x i8] c"col\00" -@fld.str.394 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.392, i64 4 }, { ptr, i64 } { ptr @fld.str.393, i64 3 }, { ptr, i64 } { ptr @fld.str.394, i64 4 }] -@str.395 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.396 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.397 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.398 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.399 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.400 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.402 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.405 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.406 = private constant [12 x i8] c"alloc_count\00" -@field_names.407 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 11 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [5 x i8] c"next\00" -@fld.str.414 = private constant [4 x i8] c"cap\00" -@field_names.415 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 4 }, { ptr, i64 } { ptr @fld.str.414, i64 3 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [4 x i8] c"ctx\00" -@fld.str.422 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.423 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.424 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 3 }, { ptr, i64 } { ptr @fld.str.422, i64 11 }, { ptr, i64 } { ptr @fld.str.423, i64 13 }] -@str.425 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.426 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.427 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.428 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.429 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.430 = private constant [6 x i8] c"first\00" -@fld.str.431 = private constant [10 x i8] c"end_index\00" -@fld.str.432 = private constant [7 x i8] c"parent\00" -@field_names.433 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.430, i64 5 }, { ptr, i64 } { ptr @fld.str.431, i64 9 }, { ptr, i64 } { ptr @fld.str.432, i64 6 }] -@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.435 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.436 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.438 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.439 = private constant [4 x i8] c"buf\00" -@fld.str.440 = private constant [4 x i8] c"len\00" -@fld.str.441 = private constant [4 x i8] c"pos\00" -@field_names.442 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 3 }, { ptr, i64 } { ptr @fld.str.440, i64 3 }, { ptr, i64 } { ptr @fld.str.441, i64 3 }] -@str.443 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.444 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.445 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.446 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.447 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.448 = private constant [7 x i8] c"parent\00" -@fld.str.449 = private constant [12 x i8] c"alloc_count\00" -@fld.str.450 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.451 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.452 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.448, i64 6 }, { ptr, i64 } { ptr @fld.str.449, i64 11 }, { ptr, i64 } { ptr @fld.str.450, i64 13 }, { ptr, i64 } { ptr @fld.str.451, i64 17 }] -@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.454 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.458 = private constant [10 x i8] c"allocator\00" -@fld.str.459 = private constant [5 x i8] c"data\00" -@field_names.460 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 9 }, { ptr, i64 } { ptr @fld.str.459, i64 4 }] -@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.462 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.463 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.465 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.466 = private constant [3 x i8] c"fd\00" -@field_names.467 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.466, i64 2 }] -@str.468 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.469 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.470 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.471 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.472 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.473 = private constant [5 x i8] c"file\00" -@fld.str.474 = private constant [5 x i8] c"line\00" -@fld.str.475 = private constant [4 x i8] c"col\00" -@fld.str.476 = private constant [5 x i8] c"func\00" -@fld.str.477 = private constant [10 x i8] c"line_text\00" -@field_names.478 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.473, i64 4 }, { ptr, i64 } { ptr @fld.str.474, i64 4 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }, { ptr, i64 } { ptr @fld.str.476, i64 4 }, { ptr, i64 } { ptr @fld.str.477, i64 9 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [10 x i8] c"exit_code\00" -@fld.str.485 = private constant [7 x i8] c"stdout\00" -@field_names.486 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 9 }, { ptr, i64 } { ptr @fld.str.485, i64 6 }] -@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.488 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.489 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.490 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.491 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.492 = private constant [8 x i8] c"sin_len\00" -@fld.str.493 = private constant [11 x i8] c"sin_family\00" -@fld.str.494 = private constant [9 x i8] c"sin_port\00" -@fld.str.495 = private constant [9 x i8] c"sin_addr\00" -@fld.str.496 = private constant [9 x i8] c"sin_zero\00" -@field_names.497 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.492, i64 7 }, { ptr, i64 } { ptr @fld.str.493, i64 10 }, { ptr, i64 } { ptr @fld.str.494, i64 8 }, { ptr, i64 } { ptr @fld.str.495, i64 8 }, { ptr, i64 } { ptr @fld.str.496, i64 8 }] -@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.499 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.503 = private constant [6 x i8] c"items\00" -@fld.str.504 = private constant [4 x i8] c"len\00" -@fld.str.505 = private constant [4 x i8] c"cap\00" -@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 5 }, { ptr, i64 } { ptr @fld.str.504, i64 3 }, { ptr, i64 } { ptr @fld.str.505, i64 3 }] -@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.508 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.512 = private constant [6 x i8] c"items\00" -@fld.str.513 = private constant [4 x i8] c"len\00" -@fld.str.514 = private constant [4 x i8] c"cap\00" -@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 5 }, { ptr, i64 } { ptr @fld.str.513, i64 3 }, { ptr, i64 } { ptr @fld.str.514, i64 3 }] -@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.517 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.521 = private constant [4 x i8] c"key\00" -@fld.str.522 = private constant [4 x i8] c"val\00" -@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 3 }] -@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.525 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.529 = private constant [4 x i8] c"dst\00" -@fld.str.530 = private constant [4 x i8] c"pos\00" -@fld.str.531 = private constant [5 x i8] c"file\00" -@field_names.532 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 3 }, { ptr, i64 } { ptr @fld.str.530, i64 3 }, { ptr, i64 } { ptr @fld.str.531, i64 4 }] -@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.534 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.535 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.536 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.537 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.538 = private constant [4 x i8] c"src\00" -@fld.str.539 = private constant [4 x i8] c"pos\00" -@fld.str.540 = private constant [6 x i8] c"alloc\00" -@field_names.541 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 3 }, { ptr, i64 } { ptr @fld.str.539, i64 3 }, { ptr, i64 } { ptr @fld.str.540, i64 5 }] -@str.542 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.543 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.544 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.546 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.547 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.549 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.550 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.551 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.552 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.553 = private constant [5 x i8] c"name\00" -@fld.str.554 = private constant [12 x i8] c"takes_value\00" -@fld.str.555 = private constant [9 x i8] c"required\00" -@field_names.556 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 11 }, { ptr, i64 } { ptr @fld.str.555, i64 8 }] -@str.557 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.558 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.559 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.561 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.562 = private constant [6 x i8] c"group\00" -@fld.str.563 = private constant [8 x i8] c"command\00" -@fld.str.564 = private constant [6 x i8] c"flags\00" -@field_names.565 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 5 }, { ptr, i64 } { ptr @fld.str.563, i64 7 }, { ptr, i64 } { ptr @fld.str.564, i64 5 }] -@str.566 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.567 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.570 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.571 = private constant [4 x i8] c"set\00" -@fld.str.572 = private constant [6 x i8] c"value\00" -@field_names.573 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.571, i64 3 }, { ptr, i64 } { ptr @fld.str.572, i64 5 }] -@str.574 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.575 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.578 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.579 = private constant [6 x i8] c"index\00" -@fld.str.580 = private constant [6 x i8] c"token\00" -@field_names.581 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }] -@str.582 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.583 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.585 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.586 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.587 = private constant [6 x i8] c"group\00" -@fld.str.588 = private constant [8 x i8] c"command\00" -@fld.str.589 = private constant [10 x i8] c"cmd_index\00" -@fld.str.590 = private constant [5 x i8] c"json\00" -@fld.str.591 = private constant [5 x i8] c"rest\00" -@fld.str.592 = private constant [5 x i8] c"spec\00" -@fld.str.593 = private constant [7 x i8] c"values\00" -@field_names.594 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }, { ptr, i64 } { ptr @fld.str.589, i64 9 }, { ptr, i64 } { ptr @fld.str.590, i64 4 }, { ptr, i64 } { ptr @fld.str.591, i64 4 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }] -@str.595 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.596 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.599 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.600 = private constant [2 x i8] c"h\00" -@fld.str.601 = private constant [4 x i8] c"buf\00" -@fld.str.602 = private constant [8 x i8] c"buf_len\00" -@fld.str.603 = private constant [10 x i8] c"total_len\00" -@field_names.604 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.600, i64 1 }, { ptr, i64 } { ptr @fld.str.601, i64 3 }, { ptr, i64 } { ptr @fld.str.602, i64 7 }, { ptr, i64 } { ptr @fld.str.603, i64 9 }] -@str.605 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.606 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.610 = private constant [5 x i8] c"data\00" -@field_names.611 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.610, i64 4 }] -@str.612 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.613 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.617 = private constant [2 x i8] c"x\00" -@fld.str.618 = private constant [2 x i8] c"y\00" -@field_names.619 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.617, i64 1 }, { ptr, i64 } { ptr @fld.str.618, i64 1 }] -@str.620 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.621 = private unnamed_addr constant [12 x i8] c"Vec__3__f32\00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.625 = private constant [5 x i8] c"data\00" -@field_names.626 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.625, i64 4 }] -@str.627 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.628 = private unnamed_addr constant [5 x i8] c"Vec3\00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.632 = private constant [5 x i8] c"data\00" -@field_names.633 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.632, i64 4 }] -@str.634 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.635 = private unnamed_addr constant [13 x i8] c"Complex__u32\00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.638 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.639 = private constant [6 x i8] c"value\00" -@fld.str.640 = private constant [6 x i8] c"count\00" -@field_names.641 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.639, i64 5 }, { ptr, i64 } { ptr @fld.str.640, i64 5 }] -@str.642 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.643 = private unnamed_addr constant [4 x i8] c"Foo\00", align 1 -@str.644 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.645 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.646 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.647 = private constant [6 x i8] c"value\00" -@fld.str.648 = private constant [6 x i8] c"count\00" -@field_names.649 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.647, i64 5 }, { ptr, i64 } { ptr @fld.str.648, i64 5 }] -@str.650 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.651 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.652 = private constant [5 x i8] c"read\00" -@fld.str.653 = private constant [6 x i8] c"write\00" -@fld.str.654 = private constant [7 x i8] c"append\00" -@fld.str.655 = private constant [11 x i8] c"read_write\00" -@field_names.656 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.652, i64 4 }, { ptr, i64 } { ptr @fld.str.653, i64 5 }, { ptr, i64 } { ptr @fld.str.654, i64 6 }, { ptr, i64 } { ptr @fld.str.655, i64 10 }] -@str.657 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.658 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.659 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.660 = private constant [4 x i8] c"set\00" -@fld.str.661 = private constant [8 x i8] c"current\00" -@fld.str.662 = private constant [4 x i8] c"end\00" -@field_names.663 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.660, i64 3 }, { ptr, i64 } { ptr @fld.str.661, i64 7 }, { ptr, i64 } { ptr @fld.str.662, i64 3 }] -@str.664 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.665 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.667 = private constant [6 x i8] c"null_\00" -@fld.str.668 = private constant [6 x i8] c"bool_\00" -@fld.str.669 = private constant [5 x i8] c"int_\00" -@fld.str.670 = private constant [4 x i8] c"str\00" -@fld.str.671 = private constant [6 x i8] c"array\00" -@fld.str.672 = private constant [7 x i8] c"object\00" -@field_names.673 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.667, i64 5 }, { ptr, i64 } { ptr @fld.str.668, i64 5 }, { ptr, i64 } { ptr @fld.str.669, i64 4 }, { ptr, i64 } { ptr @fld.str.670, i64 3 }, { ptr, i64 } { ptr @fld.str.671, i64 5 }, { ptr, i64 } { ptr @fld.str.672, i64 6 }] -@str.674 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.676 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.677 = private constant [6 x i8] c"macos\00" -@fld.str.678 = private constant [6 x i8] c"linux\00" -@fld.str.679 = private constant [8 x i8] c"windows\00" -@fld.str.680 = private constant [5 x i8] c"wasm\00" -@fld.str.681 = private constant [4 x i8] c"ios\00" -@fld.str.682 = private constant [8 x i8] c"android\00" -@fld.str.683 = private constant [8 x i8] c"unknown\00" -@field_names.684 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.677, i64 5 }, { ptr, i64 } { ptr @fld.str.678, i64 5 }, { ptr, i64 } { ptr @fld.str.679, i64 7 }, { ptr, i64 } { ptr @fld.str.680, i64 4 }, { ptr, i64 } { ptr @fld.str.681, i64 3 }, { ptr, i64 } { ptr @fld.str.682, i64 7 }, { ptr, i64 } { ptr @fld.str.683, i64 7 }] -@str.685 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.686 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.687 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.688 = private constant [8 x i8] c"aarch64\00" -@fld.str.689 = private constant [7 x i8] c"x86_64\00" -@fld.str.690 = private constant [7 x i8] c"wasm32\00" -@fld.str.691 = private constant [7 x i8] c"wasm64\00" -@fld.str.692 = private constant [8 x i8] c"unknown\00" -@field_names.693 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.688, i64 7 }, { ptr, i64 } { ptr @fld.str.689, i64 6 }, { ptr, i64 } { ptr @fld.str.690, i64 6 }, { ptr, i64 } { ptr @fld.str.691, i64 6 }, { ptr, i64 } { ptr @fld.str.692, i64 7 }] -@str.694 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.695 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.696 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.697 = private constant [8 x i8] c"counter\00" -@fld.str.698 = private constant [5 x i8] c"user\00" -@field_names.699 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.697, i64 7 }, { ptr, i64 } { ptr @fld.str.698, i64 4 }] -@str.700 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.701 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.702 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.703 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.704 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.705 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.706 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.707 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.708 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.709 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.710 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.711 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.712 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.713 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.714 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.715 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.716 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.717 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.718 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.719 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.720 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.721 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.722 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.723 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.724 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.725 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.726 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.727 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.728 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.729 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.730 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.731 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.732 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.733 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.734 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.735 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.736 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.737 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.738 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.739 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.740 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.741 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.742 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.743 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.745 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.746 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.748 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.749 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.750 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.751 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.752 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.753 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.754 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.755 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.756 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.757 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.758 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.759 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.760 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.761 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.762 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.763 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.764 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.765 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.766 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.767 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.768 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.769 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.770 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.771 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.772 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.773 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.774 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.775 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.776 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.777 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.778 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.779 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.780 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.781 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.782 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.783 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.784 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.785 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.787 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.788 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.790 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.791 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.792 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.793 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.794 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.795 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.796 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.797 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.798 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.799 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.800 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.801 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.802 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.803 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.804 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.805 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.806 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.807 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.808 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.809 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.810 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.811 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.812 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.813 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.814 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.815 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.816 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.817 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.818 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.819 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.820 = private unnamed_addr constant [6 x i8] c"*Vec3\00", align 1 -@str.821 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.822 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.823 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.824 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.825 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.826 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.827 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.828 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.829 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.830 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.831 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.832 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.833 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.834 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.835 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.836 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.837 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.838 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 -@str.839 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.840 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.841 = private unnamed_addr constant [15 x i8] c"*Vector(3,f32)\00", align 1 -@str.842 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.843 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.844 = private unnamed_addr constant [8 x i8] c"*[5]f32\00", align 1 -@str.845 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.846 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.847 = private unnamed_addr constant [5 x i8] c"*Foo\00", align 1 -@str.848 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.849 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.850 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 -@str.851 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.852 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.853 = private unnamed_addr constant [9 x i8] c"*Sx__f32\00", align 1 -@str.854 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.855 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.856 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.394 = private constant [5 x i8] c"line\00" +@fld.str.395 = private constant [4 x i8] c"col\00" +@fld.str.396 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.394, i64 4 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }, { ptr, i64 } { ptr @fld.str.396, i64 4 }] +@str.397 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.398 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.399 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.401 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.402 = private constant [4 x i8] c"ctx\00" +@fld.str.403 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.404 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.405 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.402, i64 3 }, { ptr, i64 } { ptr @fld.str.403, i64 11 }, { ptr, i64 } { ptr @fld.str.404, i64 13 }] +@str.406 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.407 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.408 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.409 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.410 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.411 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.412 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.413 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.415 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.416 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.417 = private constant [12 x i8] c"alloc_count\00" +@field_names.418 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.417, i64 11 }] +@str.419 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.420 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.422 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.423 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.424 = private constant [5 x i8] c"next\00" +@fld.str.425 = private constant [4 x i8] c"cap\00" +@field_names.426 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }] +@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.428 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.432 = private constant [6 x i8] c"first\00" +@fld.str.433 = private constant [10 x i8] c"end_index\00" +@fld.str.434 = private constant [7 x i8] c"parent\00" +@field_names.435 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 5 }, { ptr, i64 } { ptr @fld.str.433, i64 9 }, { ptr, i64 } { ptr @fld.str.434, i64 6 }] +@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.437 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.441 = private constant [4 x i8] c"buf\00" +@fld.str.442 = private constant [4 x i8] c"len\00" +@fld.str.443 = private constant [4 x i8] c"pos\00" +@field_names.444 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 3 }, { ptr, i64 } { ptr @fld.str.442, i64 3 }, { ptr, i64 } { ptr @fld.str.443, i64 3 }] +@str.445 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.446 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.447 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.448 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.449 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.450 = private constant [7 x i8] c"parent\00" +@fld.str.451 = private constant [12 x i8] c"alloc_count\00" +@fld.str.452 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.453 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.454 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.450, i64 6 }, { ptr, i64 } { ptr @fld.str.451, i64 11 }, { ptr, i64 } { ptr @fld.str.452, i64 13 }, { ptr, i64 } { ptr @fld.str.453, i64 17 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.460 = private constant [10 x i8] c"allocator\00" +@fld.str.461 = private constant [5 x i8] c"data\00" +@field_names.462 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 9 }, { ptr, i64 } { ptr @fld.str.461, i64 4 }] +@str.463 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.464 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.465 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.467 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.468 = private constant [3 x i8] c"fd\00" +@field_names.469 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.468, i64 2 }] +@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.471 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.475 = private constant [5 x i8] c"file\00" +@fld.str.476 = private constant [5 x i8] c"line\00" +@fld.str.477 = private constant [4 x i8] c"col\00" +@fld.str.478 = private constant [5 x i8] c"func\00" +@fld.str.479 = private constant [10 x i8] c"line_text\00" +@field_names.480 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 4 }, { ptr, i64 } { ptr @fld.str.476, i64 4 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 4 }, { ptr, i64 } { ptr @fld.str.479, i64 9 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [10 x i8] c"exit_code\00" +@fld.str.487 = private constant [7 x i8] c"stdout\00" +@field_names.488 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 9 }, { ptr, i64 } { ptr @fld.str.487, i64 6 }] +@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.490 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.494 = private constant [8 x i8] c"sin_len\00" +@fld.str.495 = private constant [11 x i8] c"sin_family\00" +@fld.str.496 = private constant [9 x i8] c"sin_port\00" +@fld.str.497 = private constant [9 x i8] c"sin_addr\00" +@fld.str.498 = private constant [9 x i8] c"sin_zero\00" +@field_names.499 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.494, i64 7 }, { ptr, i64 } { ptr @fld.str.495, i64 10 }, { ptr, i64 } { ptr @fld.str.496, i64 8 }, { ptr, i64 } { ptr @fld.str.497, i64 8 }, { ptr, i64 } { ptr @fld.str.498, i64 8 }] +@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.501 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.504 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.505 = private constant [6 x i8] c"items\00" +@fld.str.506 = private constant [4 x i8] c"len\00" +@fld.str.507 = private constant [4 x i8] c"cap\00" +@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 5 }, { ptr, i64 } { ptr @fld.str.506, i64 3 }, { ptr, i64 } { ptr @fld.str.507, i64 3 }] +@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.510 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.514 = private constant [6 x i8] c"items\00" +@fld.str.515 = private constant [4 x i8] c"len\00" +@fld.str.516 = private constant [4 x i8] c"cap\00" +@field_names.517 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 5 }, { ptr, i64 } { ptr @fld.str.515, i64 3 }, { ptr, i64 } { ptr @fld.str.516, i64 3 }] +@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.519 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.523 = private constant [4 x i8] c"key\00" +@fld.str.524 = private constant [4 x i8] c"val\00" +@field_names.525 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 3 }, { ptr, i64 } { ptr @fld.str.524, i64 3 }] +@str.526 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.527 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.528 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.529 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.530 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.531 = private constant [4 x i8] c"dst\00" +@fld.str.532 = private constant [4 x i8] c"pos\00" +@fld.str.533 = private constant [5 x i8] c"file\00" +@field_names.534 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.531, i64 3 }, { ptr, i64 } { ptr @fld.str.532, i64 3 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }] +@str.535 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.536 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.537 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.538 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.539 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.540 = private constant [4 x i8] c"src\00" +@fld.str.541 = private constant [4 x i8] c"pos\00" +@fld.str.542 = private constant [6 x i8] c"alloc\00" +@field_names.543 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.540, i64 3 }, { ptr, i64 } { ptr @fld.str.541, i64 3 }, { ptr, i64 } { ptr @fld.str.542, i64 5 }] +@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.545 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.546 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.548 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.549 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.551 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.552 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.553 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.554 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.555 = private constant [5 x i8] c"name\00" +@fld.str.556 = private constant [12 x i8] c"takes_value\00" +@fld.str.557 = private constant [9 x i8] c"required\00" +@field_names.558 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 11 }, { ptr, i64 } { ptr @fld.str.557, i64 8 }] +@str.559 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.560 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.561 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.563 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.564 = private constant [6 x i8] c"group\00" +@fld.str.565 = private constant [8 x i8] c"command\00" +@fld.str.566 = private constant [6 x i8] c"flags\00" +@field_names.567 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 7 }, { ptr, i64 } { ptr @fld.str.566, i64 5 }] +@str.568 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.569 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.572 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.573 = private constant [4 x i8] c"set\00" +@fld.str.574 = private constant [6 x i8] c"value\00" +@field_names.575 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }] +@str.576 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.577 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.580 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.581 = private constant [6 x i8] c"index\00" +@fld.str.582 = private constant [6 x i8] c"token\00" +@field_names.583 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 5 }] +@str.584 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.585 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.587 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.588 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.589 = private constant [6 x i8] c"group\00" +@fld.str.590 = private constant [8 x i8] c"command\00" +@fld.str.591 = private constant [10 x i8] c"cmd_index\00" +@fld.str.592 = private constant [5 x i8] c"json\00" +@fld.str.593 = private constant [5 x i8] c"rest\00" +@fld.str.594 = private constant [5 x i8] c"spec\00" +@fld.str.595 = private constant [7 x i8] c"values\00" +@field_names.596 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 5 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }, { ptr, i64 } { ptr @fld.str.591, i64 9 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 4 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }] +@str.597 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.598 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.602 = private constant [2 x i8] c"h\00" +@fld.str.603 = private constant [4 x i8] c"buf\00" +@fld.str.604 = private constant [8 x i8] c"buf_len\00" +@fld.str.605 = private constant [10 x i8] c"total_len\00" +@field_names.606 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 1 }, { ptr, i64 } { ptr @fld.str.603, i64 3 }, { ptr, i64 } { ptr @fld.str.604, i64 7 }, { ptr, i64 } { ptr @fld.str.605, i64 9 }] +@str.607 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.608 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.612 = private constant [5 x i8] c"data\00" +@field_names.613 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.612, i64 4 }] +@str.614 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.615 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.619 = private constant [2 x i8] c"x\00" +@fld.str.620 = private constant [2 x i8] c"y\00" +@field_names.621 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.619, i64 1 }, { ptr, i64 } { ptr @fld.str.620, i64 1 }] +@str.622 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.623 = private unnamed_addr constant [12 x i8] c"Vec__3__f32\00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.627 = private constant [5 x i8] c"data\00" +@field_names.628 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.627, i64 4 }] +@str.629 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.630 = private unnamed_addr constant [5 x i8] c"Vec3\00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.634 = private constant [5 x i8] c"data\00" +@field_names.635 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.634, i64 4 }] +@str.636 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.637 = private unnamed_addr constant [13 x i8] c"Complex__u32\00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.640 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.641 = private constant [6 x i8] c"value\00" +@fld.str.642 = private constant [6 x i8] c"count\00" +@field_names.643 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.641, i64 5 }, { ptr, i64 } { ptr @fld.str.642, i64 5 }] +@str.644 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.645 = private unnamed_addr constant [4 x i8] c"Foo\00", align 1 +@str.646 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.647 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.648 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.649 = private constant [6 x i8] c"value\00" +@fld.str.650 = private constant [6 x i8] c"count\00" +@field_names.651 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.649, i64 5 }, { ptr, i64 } { ptr @fld.str.650, i64 5 }] +@str.652 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.653 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.654 = private constant [5 x i8] c"read\00" +@fld.str.655 = private constant [6 x i8] c"write\00" +@fld.str.656 = private constant [7 x i8] c"append\00" +@fld.str.657 = private constant [11 x i8] c"read_write\00" +@field_names.658 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.654, i64 4 }, { ptr, i64 } { ptr @fld.str.655, i64 5 }, { ptr, i64 } { ptr @fld.str.656, i64 6 }, { ptr, i64 } { ptr @fld.str.657, i64 10 }] +@str.659 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.660 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.661 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.662 = private constant [4 x i8] c"set\00" +@fld.str.663 = private constant [8 x i8] c"current\00" +@fld.str.664 = private constant [4 x i8] c"end\00" +@field_names.665 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.662, i64 3 }, { ptr, i64 } { ptr @fld.str.663, i64 7 }, { ptr, i64 } { ptr @fld.str.664, i64 3 }] +@str.666 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.667 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.669 = private constant [6 x i8] c"null_\00" +@fld.str.670 = private constant [6 x i8] c"bool_\00" +@fld.str.671 = private constant [5 x i8] c"int_\00" +@fld.str.672 = private constant [4 x i8] c"str\00" +@fld.str.673 = private constant [6 x i8] c"array\00" +@fld.str.674 = private constant [7 x i8] c"object\00" +@field_names.675 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.669, i64 5 }, { ptr, i64 } { ptr @fld.str.670, i64 5 }, { ptr, i64 } { ptr @fld.str.671, i64 4 }, { ptr, i64 } { ptr @fld.str.672, i64 3 }, { ptr, i64 } { ptr @fld.str.673, i64 5 }, { ptr, i64 } { ptr @fld.str.674, i64 6 }] +@str.676 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.678 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.679 = private constant [6 x i8] c"macos\00" +@fld.str.680 = private constant [6 x i8] c"linux\00" +@fld.str.681 = private constant [8 x i8] c"windows\00" +@fld.str.682 = private constant [5 x i8] c"wasm\00" +@fld.str.683 = private constant [4 x i8] c"ios\00" +@fld.str.684 = private constant [8 x i8] c"android\00" +@fld.str.685 = private constant [8 x i8] c"unknown\00" +@field_names.686 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.679, i64 5 }, { ptr, i64 } { ptr @fld.str.680, i64 5 }, { ptr, i64 } { ptr @fld.str.681, i64 7 }, { ptr, i64 } { ptr @fld.str.682, i64 4 }, { ptr, i64 } { ptr @fld.str.683, i64 3 }, { ptr, i64 } { ptr @fld.str.684, i64 7 }, { ptr, i64 } { ptr @fld.str.685, i64 7 }] +@str.687 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.688 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.689 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.690 = private constant [8 x i8] c"aarch64\00" +@fld.str.691 = private constant [7 x i8] c"x86_64\00" +@fld.str.692 = private constant [7 x i8] c"wasm32\00" +@fld.str.693 = private constant [7 x i8] c"wasm64\00" +@fld.str.694 = private constant [8 x i8] c"unknown\00" +@field_names.695 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.690, i64 7 }, { ptr, i64 } { ptr @fld.str.691, i64 6 }, { ptr, i64 } { ptr @fld.str.692, i64 6 }, { ptr, i64 } { ptr @fld.str.693, i64 6 }, { ptr, i64 } { ptr @fld.str.694, i64 7 }] +@str.696 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.697 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.698 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.699 = private constant [8 x i8] c"counter\00" +@fld.str.700 = private constant [5 x i8] c"user\00" +@field_names.701 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.699, i64 7 }, { ptr, i64 } { ptr @fld.str.700, i64 4 }] +@str.702 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.703 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.704 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.705 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.706 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.707 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.708 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.709 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.710 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.711 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.712 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.713 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.714 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.715 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.716 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.717 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.718 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.719 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.720 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.721 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.722 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.723 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.724 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.725 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.726 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.727 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.728 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.729 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.730 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.731 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.732 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.733 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.734 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.735 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.736 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.737 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.738 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.739 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.740 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.741 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.742 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.743 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.744 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.745 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.747 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.750 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.753 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.756 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.759 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.762 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.765 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.768 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.771 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.774 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.777 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.780 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.783 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.786 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.787 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.789 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.790 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.791 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.792 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.793 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.795 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.796 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.798 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.799 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.800 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.801 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.802 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.803 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.804 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.805 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.806 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.807 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.808 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.809 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.810 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.811 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.812 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.813 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.814 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.815 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.816 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.817 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.818 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.819 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.820 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.821 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.822 = private unnamed_addr constant [6 x i8] c"*Vec3\00", align 1 +@str.823 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.824 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.825 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.826 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.827 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.828 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.829 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.830 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.831 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.832 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.833 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.834 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.835 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.836 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.837 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.838 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.839 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.840 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 +@str.841 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.842 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.843 = private unnamed_addr constant [15 x i8] c"*Vector(3,f32)\00", align 1 +@str.844 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.845 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.846 = private unnamed_addr constant [8 x i8] c"*[5]f32\00", align 1 +@str.847 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.848 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.849 = private unnamed_addr constant [5 x i8] c"*Foo\00", align 1 +@str.850 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.851 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.852 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 +@str.853 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.854 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.855 = private unnamed_addr constant [9 x i8] c"*Sx__f32\00", align 1 +@str.856 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.857 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.858 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.859 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.860 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -754,6 +754,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -973,7 +976,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1100,7 +1103,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1434,7 +1437,7 @@ entry: br i1 %icmp, label %if.then.434, label %if.merge.435 if.then.434: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.435: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1585,7 +1588,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1611,9 +1614,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1664,9 +1667,9 @@ entry: i64 85, label %match.arm.48 i64 105, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1712,7 +1715,7 @@ match.merge.37: ; preds = %dispatch.merge.555, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1756,9 +1759,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1853,9 +1856,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw41, label %dispatch.default.393 [ i64 18, label %dispatch.case.394 - i64 21, label %dispatch.case.395 - i64 23, label %dispatch.case.396 - i64 25, label %dispatch.case.397 + i64 22, label %dispatch.case.395 + i64 24, label %dispatch.case.396 + i64 26, label %dispatch.case.397 i64 28, label %dispatch.case.398 i64 29, label %dispatch.case.399 i64 31, label %dispatch.case.400 @@ -1959,7 +1962,7 @@ dispatch.merge.94: ; preds = %dispatch.case.126, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1973,32 +1976,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { ptr, ptr, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) + %ua.load74 = load {}, ptr %ua.ptr73, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) + %ua.load78 = load { i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, ptr, ptr }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load82) + %ua.load82 = load { ptr, i64 }, ptr %ua.ptr81, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load82) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2216,7 +2219,7 @@ dispatch.merge.282: ; preds = %dispatch.case.289, br label %match.merge.37 dispatch.default.283: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.331, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.282 dispatch.case.284: ; preds = %match.arm.44 @@ -2265,7 +2268,7 @@ dispatch.merge.302: ; preds = %dispatch.case.304, br label %match.merge.37 dispatch.default.303: ; preds = %match.arm.46 - store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.302 dispatch.case.304: ; preds = %match.arm.46 @@ -2282,7 +2285,7 @@ dispatch.merge.310: ; preds = %dispatch.case.319, br label %match.merge.37 dispatch.default.311: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.310 dispatch.case.312: ; preds = %match.arm.47 @@ -2355,7 +2358,7 @@ dispatch.merge.360: ; preds = %dispatch.case.366, br label %match.merge.37 dispatch.default.361: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.360 dispatch.case.362: ; preds = %match.arm.48 @@ -2404,7 +2407,7 @@ dispatch.merge.392: ; preds = %dispatch.case.430, br label %match.merge.37 dispatch.default.393: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.392 dispatch.case.394: ; preds = %match.arm.49 @@ -2672,7 +2675,7 @@ dispatch.merge.555: ; preds = %dispatch.case.560, br label %match.merge.37 dispatch.default.556: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.338, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.555 dispatch.case.557: ; preds = %match.arm.50 @@ -2714,7 +2717,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.337, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.339, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2810,7 +2813,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2818,7 +2821,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2828,13 +2831,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2842,7 +2845,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2856,7 +2859,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2864,7 +2867,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2875,7 +2878,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2932,7 +2935,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2940,7 +2943,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2951,7 +2954,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2971,7 +2974,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2979,7 +2982,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, 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 @@ -2990,7 +2993,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -3000,64 +3003,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3233,163 +3239,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3587,64 +3596,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3674,97 +3683,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3803,7 +3812,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3982,7 +3991,7 @@ entry: define internal void @print__ct_saf3b53dfd1590ed__pack_Vec3(ptr %0, { <3 x float> } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.352, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.354, i64 7 }, ptr %alloca, align 8 %allocaN = alloca { <3 x float> }, align 16 store { <3 x float> } %1, ptr %allocaN, align 16 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4000,7 +4009,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.353, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.355, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 4) @@ -4030,7 +4039,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.354, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.356, i64 7 }) ret { ptr, i64 } %call } @@ -4038,7 +4047,7 @@ entry: define internal void @print__ct_s962c60eb1430613f__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.355, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.357, i64 7 }, ptr %alloca, align 8 %allocaN = alloca <3 x float>, align 16 store <3 x float> %1, ptr %allocaN, align 16 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4056,7 +4065,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.356, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.358, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 4) @@ -4086,7 +4095,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.357, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.359, i64 7 }) ret { ptr, i64 } %call } @@ -4094,7 +4103,7 @@ entry: define internal void @print__ct_s549467baf058e667__pack_AR_5_f32(ptr %0, [5 x float] %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.358, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.360, i64 9 }, ptr %alloca, align 8 %allocaN = alloca [5 x float], align 4 store [5 x float] %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4112,7 +4121,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.359, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.361, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -4142,7 +4151,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.360, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.362, i64 9 }) ret { ptr, i64 } %call } @@ -4150,7 +4159,7 @@ entry: define internal void @print__ct_sd91eb2e81c05dcd4__pack_Foo(ptr %0, { i32, i32 } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.361, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.363, i64 9 }, ptr %alloca, align 8 %allocaN = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4168,7 +4177,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.362, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.364, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -4198,7 +4207,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_3(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.363, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.365, i64 9 }) ret { ptr, i64 } %call } @@ -4206,7 +4215,7 @@ entry: define internal void @print__ct_s3038067ddd716595__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.364, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.366, i64 8 }, ptr %alloca, align 8 %allocaN = alloca <3 x float>, align 16 store <3 x float> %1, ptr %allocaN, align 16 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4224,7 +4233,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.365, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.367, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4254,7 +4263,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_4(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.366, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.368, i64 8 }) ret { ptr, i64 } %call } @@ -4262,7 +4271,7 @@ entry: define internal void @print__ct_sb50fffa856c31fe8__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.367, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.369, i64 9 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4279,7 +4288,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.368, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.370, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -4308,7 +4317,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_5(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.369, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.371, i64 9 }) ret { ptr, i64 } %call } @@ -4316,7 +4325,7 @@ entry: define internal void @print__ct_sd243afec30847211__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.370, i64 10 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.372, i64 10 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4333,7 +4342,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.371, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.373, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 7) @@ -4362,7 +4371,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_6(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.372, i64 10 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.374, i64 10 }) ret { ptr, i64 } %call } @@ -4370,7 +4379,7 @@ entry: define internal void @print__ct_s1e80f4429411a63__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.373, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.375, i64 11 }, ptr %alloca, align 8 %allocaN = alloca <3 x float>, align 16 store <3 x float> %1, ptr %allocaN, align 16 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4388,7 +4397,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.374, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.376, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -4418,7 +4427,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_7(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.375, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.377, i64 11 }) ret { ptr, i64 } %call } @@ -4426,7 +4435,7 @@ entry: define internal void @print__ct_sd428128013c58f8b__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.376, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.378, i64 8 }, ptr %alloca, align 8 %allocaN = alloca <3 x float>, align 16 store <3 x float> %1, ptr %allocaN, align 16 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4444,7 +4453,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.377, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.379, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4474,7 +4483,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_8(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.378, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.380, i64 8 }) ret { ptr, i64 } %call } @@ -4491,7 +4500,7 @@ entry: define internal void @print__ct_sa2a846ee0ce9045d__pack_f64(ptr %0, double %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.379, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.381, i64 12 }, ptr %alloca, align 8 %allocaN = alloca double, align 8 store double %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4507,7 +4516,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.380, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.382, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 9) @@ -4535,7 +4544,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_9(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.381, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.383, i64 12 }) ret { ptr, i64 } %call } @@ -4543,7 +4552,7 @@ entry: define internal void @print__ct_sbc6305862a3a863d__pack_Sx__f32(ptr %0, { i64, [4 x i8] } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.382, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.384, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { i64, [4 x i8] }, align 8 store { i64, [4 x i8] } %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4561,7 +4570,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.383, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.385, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, [4 x i8] }, ptr %allocaN, align 8 %ba.tmp9 = alloca { i64, [4 x i8] }, align 8 @@ -4586,7 +4595,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_10(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.384, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.386, i64 3 }) ret { ptr, i64 } %call } @@ -4594,7 +4603,7 @@ entry: define internal void @print__ct_sbc6305862a3a863d__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.385, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.387, i64 3 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4609,7 +4618,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.386, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.388, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -4631,7 +4640,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_11(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.387, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.389, i64 3 }) ret { ptr, i64 } %call } @@ -4642,7 +4651,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 15 }, { ptr, i64 } { ptr @str.389, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 15 }, { ptr, i64 } { ptr @str.391, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4661,12 +4670,12 @@ while.body.128: ; preds = %while.hdr.127 while.exit.129: ; preds = %while.hdr.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) ret { ptr, i64 } %callN if.then.130: ; preds = %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.131 @@ -4678,7 +4687,7 @@ if.merge.131: ; preds = %if.then.130, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4731,20 +4740,20 @@ fv.case24: ; preds = %if.merge.131 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.396, i64 10 }, { ptr, i64 } { ptr @str.397, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 9 }, { ptr, i64 } { ptr @str.399, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.132 -while.hdr.132: ; preds = %if.merge.136, %entry +while.hdr.132: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.133, label %while.exit.134 while.body.133: ; preds = %while.hdr.132 @@ -4754,224 +4763,24 @@ while.body.133: ; preds = %while.hdr.132 while.exit.134: ; preds = %while.hdr.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 1 }) ret { ptr, i64 } %callN if.then.135: ; preds = %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.136 if.merge.136: ; preds = %if.then.135, %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.400, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.405, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.132 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 3 }, { ptr, i64 } { ptr @str.403, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.137 - -while.hdr.137: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.138, label %while.exit.139 - -while.body.138: ; preds = %while.hdr.137 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.140, label %if.merge.141 - -while.exit.139: ; preds = %while.hdr.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 1 }) - ret { ptr, i64 } %callN - -if.then.140: ; preds = %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.141 - -if.merge.141: ; preds = %if.then.140, %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 - -fv.default: ; preds = %if.merge.141 - br label %fv.merge - -fv.case: ; preds = %if.merge.141 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 10 }, { ptr, i64 } { ptr @str.410, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 - -while.hdr.142: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.143, label %while.exit.144 - -while.body.143: ; preds = %while.hdr.142 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 - -while.exit.144: ; preds = %while.hdr.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) - ret { ptr, i64 } %callN - -if.then.145: ; preds = %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 - -if.merge.146: ; preds = %if.then.145, %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.415, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 - -fv.default: ; preds = %if.merge.146 - br label %fv.merge - -fv.case: ; preds = %if.merge.146 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.146 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 9 }, { ptr, i64 } { ptr @str.418, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 - -while.hdr.147: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.148, label %while.exit.149 - -while.body.148: ; preds = %while.hdr.147 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 - -while.exit.149: ; preds = %while.hdr.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) - ret { ptr, i64 } %callN - -if.then.150: ; preds = %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 - -if.merge.151: ; preds = %if.then.150, %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.424, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, 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 @@ -4990,27 +4799,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.132 + +fv.default: ; preds = %if.merge.136 + br label %fv.merge + +fv.case: ; preds = %if.merge.136 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.136 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.136 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 10 }, { ptr, i64 } { ptr @str.408, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.137 + +while.hdr.137: ; preds = %if.merge.141, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.138, label %while.exit.139 + +while.body.138: ; preds = %while.hdr.137 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.140, label %if.merge.141 + +while.exit.139: ; preds = %while.hdr.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 1 }) + ret { ptr, i64 } %callN + +if.then.140: ; preds = %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.141 + +if.merge.141: ; preds = %if.then.140, %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.411, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.413, i64 3 }, { ptr, i64 } { ptr @str.414, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.142 + +while.hdr.142: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.143, label %while.exit.144 + +while.body.143: ; preds = %while.hdr.142 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.145, label %if.merge.146 + +while.exit.144: ; preds = %while.hdr.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 1 }) + ret { ptr, i64 } %callN + +if.then.145: ; preds = %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.146 + +if.merge.146: ; preds = %if.then.145, %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.418, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.142 + +fv.default: ; preds = %if.merge.146 + br label %fv.merge + +fv.case: ; preds = %if.merge.146 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.420, i64 10 }, { ptr, i64 } { ptr @str.421, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.147 + +while.hdr.147: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.148, label %while.exit.149 + +while.body.148: ; preds = %while.hdr.147 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.150, label %if.merge.151 + +while.exit.149: ; preds = %while.hdr.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 1 }) + ret { ptr, i64 } %callN + +if.then.150: ; preds = %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.151 + +if.merge.151: ; preds = %if.then.150, %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.147 fv.default: ; preds = %if.merge.151 br label %fv.merge fv.case: ; preds = %if.merge.151 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.151 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.151 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -5020,7 +5029,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 5 }, { ptr, i64 } { ptr @str.427, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 5 }, { ptr, i64 } { ptr @str.429, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5039,24 +5048,24 @@ while.body.153: ; preds = %while.hdr.152 while.exit.154: ; preds = %while.hdr.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) ret { ptr, i64 } %callN if.then.155: ; preds = %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.156 if.merge.156: ; preds = %if.then.155, %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.433, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, 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 @@ -5083,7 +5092,7 @@ fv.default: ; preds = %if.merge.156 fv.case: ; preds = %if.merge.156 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.156 @@ -5095,7 +5104,7 @@ fv.case20: ; preds = %if.merge.156 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -5104,7 +5113,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 8 }, { ptr, i64 } { ptr @str.436, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 8 }, { ptr, i64 } { ptr @str.438, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5123,24 +5132,24 @@ while.body.158: ; preds = %while.hdr.157 while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) ret { ptr, i64 } %callN if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.161 if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.442, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.444, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, 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 @@ -5187,7 +5196,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.444, i64 17 }, { ptr, i64 } { ptr @str.445, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.446, i64 17 }, { ptr, i64 } { ptr @str.447, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5206,24 +5215,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5252,7 +5261,7 @@ fv.case: ; preds = %if.merge.166 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 @@ -5277,7 +5286,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 7 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 7 }, { ptr, i64 } { ptr @str.457, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5296,24 +5305,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %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.460, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.462, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, 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 @@ -5340,7 +5349,7 @@ fv.case: ; preds = %if.merge.171 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 @@ -5355,7 +5364,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 4 }, { ptr, i64 } { ptr @str.463, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.464, i64 4 }, { ptr, i64 } { ptr @str.465, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5374,24 +5383,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %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.467, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.469, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -5428,7 +5437,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.469, i64 10 }, { ptr, i64 } { ptr @str.470, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 10 }, { ptr, i64 } { ptr @str.472, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5447,24 +5456,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5530,7 +5539,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 13 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 13 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5549,24 +5558,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %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.486, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.488, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5608,7 +5617,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 8 }, { ptr, i64 } { ptr @str.489, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 8 }, { ptr, i64 } { ptr @str.491, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5627,24 +5636,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.497, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.499, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5705,7 +5714,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 5 }, { ptr, i64 } { ptr @str.500, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 5 }, { ptr, i64 } { ptr @str.502, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5724,24 +5733,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %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.506, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.508, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, 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 @@ -5787,7 +5796,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 6 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 6 }, { ptr, i64 } { ptr @str.511, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5806,24 +5815,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %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.515, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.517, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, 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 @@ -5871,7 +5880,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 6 }, { ptr, i64 } { ptr @str.518, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 6 }, { ptr, i64 } { ptr @str.520, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5890,24 +5899,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.523, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.525, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5951,7 +5960,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 4 }, { ptr, i64 } { ptr @str.526, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.527, i64 4 }, { ptr, i64 } { ptr @str.528, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5970,24 +5979,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.532, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.534, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -6037,7 +6046,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 6 }, { ptr, i64 } { ptr @str.535, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.536, i64 6 }, { ptr, i64 } { ptr @str.537, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6056,24 +6065,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.541, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.543, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -6113,7 +6122,7 @@ fv.case20: ; preds = %if.merge.216 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -6122,7 +6131,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.543, i64 12 }, { ptr, i64 } { ptr @str.544, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 12 }, { ptr, i64 } { ptr @str.546, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6141,24 +6150,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.547, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.549, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6178,7 +6187,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 8 }, { ptr, i64 } { ptr @str.550, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, i64 8 }, { ptr, i64 } { ptr @str.552, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6197,24 +6206,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.556, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.558, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.559, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -6266,7 +6275,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, i64 7 }, { ptr, i64 } { ptr @str.559, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 7 }, { ptr, i64 } { ptr @str.561, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6285,24 +6294,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.565, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.567, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6354,7 +6363,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 9 }, { ptr, i64 } { ptr @str.568, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 9 }, { ptr, i64 } { ptr @str.570, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6373,24 +6382,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.576, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6433,7 +6442,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, i64 4 }, { ptr, i64 } { ptr @str.576, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 4 }, { ptr, i64 } { ptr @str.578, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6452,24 +6461,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %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.581, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6515,7 +6524,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 6 }, { ptr, i64 } { ptr @str.584, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, i64 6 }, { ptr, i64 } { ptr @str.586, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6534,24 +6543,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.586, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -6633,7 +6642,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.596, i64 6 }, { ptr, i64 } { ptr @str.597, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, i64 6 }, { ptr, i64 } { ptr @str.599, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6652,24 +6661,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.604, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.606, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6725,7 +6734,7 @@ entry: %alloca = alloca { [16 x float] }, align 8 %ba.tmp = alloca [16 x float], align 4 store { [16 x float] } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, i64 4 }, { ptr, i64 } { ptr @str.607, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, i64 4 }, { ptr, i64 } { ptr @str.609, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6744,24 +6753,24 @@ while.body.253: ; preds = %while.hdr.252 while.exit.254: ; preds = %while.hdr.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %callN if.then.255: ; preds = %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 if.merge.256: ; preds = %if.then.255, %while.body.253 %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.611, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.613, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -6796,7 +6805,7 @@ define internal { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %1 entry: %alloca = alloca { float, float }, align 8 store { float, float } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.613, i64 4 }, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.615, i64 4 }, { ptr, i64 } { ptr @str.616, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6815,24 +6824,24 @@ while.body.258: ; preds = %while.hdr.257 while.exit.259: ; preds = %while.hdr.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) ret { ptr, i64 } %callN if.then.260: ; preds = %while.body.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.261 if.merge.261: ; preds = %if.then.260, %while.body.258 %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.619, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.621, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -6876,7 +6885,7 @@ entry: %alloca = alloca { <3 x float> }, align 16 %ba.tmp = alloca <3 x float>, align 16 store { <3 x float> } %1, ptr %alloca, align 16 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, i64 11 }, { ptr, i64 } { ptr @str.622, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.623, i64 11 }, { ptr, i64 } { ptr @str.624, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6895,24 +6904,24 @@ while.body.263: ; preds = %while.hdr.262 while.exit.264: ; preds = %while.hdr.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %callN if.then.265: ; preds = %while.body.263 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 if.merge.266: ; preds = %if.then.265, %while.body.263 %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.626, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.628, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { <3 x float> }, ptr %alloca, align 16 @@ -6948,7 +6957,7 @@ entry: %alloca = alloca { <3 x float> }, align 16 %ba.tmp = alloca <3 x float>, align 16 store { <3 x float> } %1, ptr %alloca, align 16 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 4 }, { ptr, i64 } { ptr @str.629, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 4 }, { ptr, i64 } { ptr @str.631, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6967,24 +6976,24 @@ while.body.268: ; preds = %while.hdr.267 while.exit.269: ; preds = %while.hdr.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) ret { ptr, i64 } %callN if.then.270: ; preds = %while.body.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.271 if.merge.271: ; preds = %if.then.270, %while.body.268 %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.633, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.635, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { <3 x float> }, ptr %alloca, align 16 @@ -7019,7 +7028,7 @@ define internal { ptr, i64 } @struct_to_string__Complex__u32(ptr %0, { i32, i32 entry: %alloca = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 12 }, { ptr, i64 } { ptr @str.636, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 12 }, { ptr, i64 } { ptr @str.638, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7038,24 +7047,24 @@ while.body.273: ; preds = %while.hdr.272 while.exit.274: ; preds = %while.hdr.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) ret { ptr, i64 } %callN if.then.275: ; preds = %while.body.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 if.merge.276: ; preds = %if.then.275, %while.body.273 %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.641, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.643, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.644, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7096,7 +7105,7 @@ define internal { ptr, i64 } @struct_to_string__Foo(ptr %0, { i32, i32 } %1) #0 entry: %alloca = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } { ptr @str.644, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } { ptr @str.646, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7115,24 +7124,24 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.645, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.647, i64 1 }) ret { ptr, i64 } %callN if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.646, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.648, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 if.merge.281: ; preds = %if.then.280, %while.body.278 %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.649, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.651, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.650, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.652, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7177,9 +7186,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.656, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.658, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, 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 @@ -7198,8 +7207,8 @@ entry: if.then.290: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -7218,9 +7227,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.663, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.665, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, 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 @@ -7239,8 +7248,8 @@ entry: if.then.292: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.293 @@ -7270,9 +7279,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.673, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.675, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -7289,8 +7298,8 @@ entry: if.then.294: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -7368,9 +7377,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.684, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.686, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, 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 @@ -7389,8 +7398,8 @@ entry: if.then.296: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.297 @@ -7409,9 +7418,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.693, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.695, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, 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 @@ -7430,8 +7439,8 @@ entry: if.then.298: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.299 @@ -7455,9 +7464,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.699, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.701, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [4 x i8] }, ptr %alloca, align 8 @@ -7470,8 +7479,8 @@ entry: if.then.300: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.701, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.703, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.301 @@ -7518,7 +7527,7 @@ entry: %alloca = alloca <3 x float>, align 16 store <3 x float> %1, ptr %alloca, align 16 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.702, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.704, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.305 @@ -7535,12 +7544,12 @@ while.body.306: ; preds = %while.hdr.305 while.exit.307: ; preds = %while.hdr.305 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.703, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 1 }) ret { ptr, i64 } %call if.then.308: ; preds = %while.body.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.704, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.309 @@ -7569,7 +7578,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.705, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.707, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7586,12 +7595,12 @@ while.body.321: ; preds = %while.hdr.320 while.exit.322: ; preds = %while.hdr.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.708, i64 1 }) ret { ptr, i64 } %call if.then.323: ; preds = %while.body.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.707, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7620,7 +7629,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.708, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.710, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.325 @@ -7637,12 +7646,12 @@ while.body.326: ; preds = %while.hdr.325 while.exit.327: ; preds = %while.hdr.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.711, i64 1 }) ret { ptr, i64 } %call if.then.328: ; preds = %while.body.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.710, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.329 @@ -7672,7 +7681,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.711, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.713, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.330 @@ -7689,12 +7698,12 @@ while.body.331: ; preds = %while.hdr.330 while.exit.332: ; preds = %while.hdr.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.714, i64 1 }) ret { ptr, i64 } %call if.then.333: ; preds = %while.body.331 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.715, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.334 @@ -7722,7 +7731,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.714, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.716, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.335 @@ -7739,12 +7748,12 @@ while.body.336: ; preds = %while.hdr.335 while.exit.337: ; preds = %while.hdr.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.715, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.717, i64 1 }) ret { ptr, i64 } %call if.then.338: ; preds = %while.body.336 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.716, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.718, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.339 @@ -7773,7 +7782,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.717, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.719, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.340 @@ -7790,12 +7799,12 @@ while.body.341: ; preds = %while.hdr.340 while.exit.342: ; preds = %while.hdr.340 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.718, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.720, i64 1 }) ret { ptr, i64 } %call if.then.343: ; preds = %while.body.341 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.721, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.344 @@ -7823,7 +7832,7 @@ entry: %ig.tmp = alloca [16 x float], align 4 store [16 x float] %1, ptr %alloca, align 4 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.720, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.722, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.345 @@ -7840,12 +7849,12 @@ while.body.346: ; preds = %while.hdr.345 while.exit.347: ; preds = %while.hdr.345 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.721, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, i64 1 }) ret { ptr, i64 } %call if.then.348: ; preds = %while.body.346 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.722, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.724, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.349 @@ -7876,7 +7885,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.723, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.725, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.350 @@ -7893,12 +7902,12 @@ while.body.351: ; preds = %while.hdr.350 while.exit.352: ; preds = %while.hdr.350 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.724, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.726, i64 1 }) ret { ptr, i64 } %call if.then.353: ; preds = %while.body.351 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.725, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.354 @@ -7928,7 +7937,7 @@ entry: %ig.tmp = alloca [5 x float], align 4 store [5 x float] %1, ptr %alloca, align 4 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.726, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.728, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.355 @@ -7945,12 +7954,12 @@ while.body.356: ; preds = %while.hdr.355 while.exit.357: ; preds = %while.hdr.355 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.729, i64 1 }) ret { ptr, i64 } %call if.then.358: ; preds = %while.body.356 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.728, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.730, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.359 @@ -7980,7 +7989,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.729, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.731, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.367 @@ -7999,12 +8008,12 @@ while.body.368: ; preds = %while.hdr.367 while.exit.369: ; preds = %while.hdr.367 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.730, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.732, i64 1 }) ret { ptr, i64 } %call if.then.370: ; preds = %while.body.368 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.733, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.371 @@ -8033,7 +8042,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.732, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.734, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.372 @@ -8052,12 +8061,12 @@ while.body.373: ; preds = %while.hdr.372 while.exit.374: ; preds = %while.hdr.372 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.733, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.735, i64 1 }) ret { ptr, i64 } %call if.then.375: ; preds = %while.body.373 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.734, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.376 @@ -8086,7 +8095,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.735, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.737, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.377 @@ -8105,12 +8114,12 @@ while.body.378: ; preds = %while.hdr.377 while.exit.379: ; preds = %while.hdr.377 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.738, i64 1 }) ret { ptr, i64 } %call if.then.380: ; preds = %while.body.378 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.737, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.739, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.381 @@ -8140,7 +8149,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.738, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.740, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.382 @@ -8159,12 +8168,12 @@ while.body.383: ; preds = %while.hdr.382 while.exit.384: ; preds = %while.hdr.382 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.739, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.741, i64 1 }) ret { ptr, i64 } %call if.then.385: ; preds = %while.body.383 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.742, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.386 @@ -8194,7 +8203,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.741, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.743, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.387 @@ -8213,12 +8222,12 @@ while.body.388: ; preds = %while.hdr.387 while.exit.389: ; preds = %while.hdr.387 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.742, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.744, i64 1 }) ret { ptr, i64 } %call if.then.390: ; preds = %while.body.388 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.743, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.745, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.391 @@ -8260,12 +8269,12 @@ if.then.431: ; preds = %entry if.else.432: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 5 }, { ptr, i64 } %callN) br label %if.merge.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -8288,12 +8297,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 11 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -8316,12 +8325,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 4 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -8344,12 +8353,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 11 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -8372,12 +8381,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 6 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -8399,12 +8408,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 5 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -8427,12 +8436,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 9 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -8455,12 +8464,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 18 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -8483,12 +8492,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 5 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -8511,12 +8520,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 3 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -8539,12 +8548,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 4 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -8567,12 +8576,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 9 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -8595,12 +8604,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 4 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -8622,12 +8631,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 8 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.785, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -8650,12 +8659,12 @@ if.then.486: ; preds = %entry if.else.487: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 6 }, { ptr, i64 } %callN) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.788, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -8677,12 +8686,12 @@ if.then.489: ; preds = %entry if.else.490: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 9 }, { ptr, i64 } %callN) br label %if.merge.491 if.merge.491: ; preds = %if.else.490, %if.then.489 - %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.791, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -8705,12 +8714,12 @@ if.then.492: ; preds = %entry if.else.493: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 7 }, { ptr, i64 } %callN) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.794, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -8733,12 +8742,12 @@ if.then.495: ; preds = %entry if.else.496: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 5 }, { ptr, i64 } %callN) br label %if.merge.497 if.merge.497: ; preds = %if.else.496, %if.then.495 - %bp = phi { ptr, i64 } [ { ptr @str.795, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.797, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -8761,12 +8770,12 @@ if.then.498: ; preds = %entry if.else.499: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 7 }, { ptr, i64 } %callN) br label %if.merge.500 if.merge.500: ; preds = %if.else.499, %if.then.498 - %bp = phi { ptr, i64 } [ { ptr @str.798, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -8789,12 +8798,12 @@ if.then.501: ; preds = %entry if.else.502: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 4 }, { ptr, i64 } %callN) br label %if.merge.503 if.merge.503: ; preds = %if.else.502, %if.then.501 - %bp = phi { ptr, i64 } [ { ptr @str.801, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.803, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -8817,12 +8826,12 @@ if.then.504: ; preds = %entry if.else.505: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 7 }, { ptr, i64 } %callN) br label %if.merge.506 if.merge.506: ; preds = %if.else.505, %if.then.504 - %bp = phi { ptr, i64 } [ { ptr @str.804, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.806, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -8845,12 +8854,12 @@ if.then.507: ; preds = %entry if.else.508: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.811, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 5 }, { ptr, i64 } %callN) br label %if.merge.509 if.merge.509: ; preds = %if.else.508, %if.then.507 - %bp = phi { ptr, i64 } [ { ptr @str.807, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.809, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -8873,12 +8882,12 @@ if.then.510: ; preds = %entry if.else.511: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.812, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.811, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.814, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 7 }, { ptr, i64 } %callN) br label %if.merge.512 if.merge.512: ; preds = %if.else.511, %if.then.510 - %bp = phi { ptr, i64 } [ { ptr @str.810, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.812, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -8901,12 +8910,12 @@ if.then.513: ; preds = %entry if.else.514: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.815, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.814, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.817, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.816, i64 12 }, { ptr, i64 } %callN) br label %if.merge.515 if.merge.515: ; preds = %if.else.514, %if.then.513 - %bp = phi { ptr, i64 } [ { ptr @str.813, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.815, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -8929,12 +8938,12 @@ if.then.516: ; preds = %entry if.else.517: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.818, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.817, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.820, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.819, i64 6 }, { ptr, i64 } %callN) br label %if.merge.518 if.merge.518: ; preds = %if.else.517, %if.then.516 - %bp = phi { ptr, i64 } [ { ptr @str.816, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] + %bp = phi { ptr, i64 } [ { ptr @str.818, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] ret { ptr, i64 } %bp } @@ -8957,12 +8966,12 @@ if.then.519: ; preds = %entry if.else.520: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.821, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.820, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.823, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.822, i64 5 }, { ptr, i64 } %callN) br label %if.merge.521 if.merge.521: ; preds = %if.else.520, %if.then.519 - %bp = phi { ptr, i64 } [ { ptr @str.819, i64 4 }, %if.then.519 ], [ %callN, %if.else.520 ] + %bp = phi { ptr, i64 } [ { ptr @str.821, i64 4 }, %if.then.519 ], [ %callN, %if.else.520 ] ret { ptr, i64 } %bp } @@ -8985,12 +8994,12 @@ if.then.522: ; preds = %entry if.else.523: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.824, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.823, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.826, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.825, i64 7 }, { ptr, i64 } %callN) br label %if.merge.524 if.merge.524: ; preds = %if.else.523, %if.then.522 - %bp = phi { ptr, i64 } [ { ptr @str.822, i64 4 }, %if.then.522 ], [ %callN, %if.else.523 ] + %bp = phi { ptr, i64 } [ { ptr @str.824, i64 4 }, %if.then.522 ], [ %callN, %if.else.523 ] ret { ptr, i64 } %bp } @@ -9013,12 +9022,12 @@ if.then.525: ; preds = %entry if.else.526: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.827, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.826, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.829, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.828, i64 4 }, { ptr, i64 } %callN) br label %if.merge.527 if.merge.527: ; preds = %if.else.526, %if.then.525 - %bp = phi { ptr, i64 } [ { ptr @str.825, i64 4 }, %if.then.525 ], [ %callN, %if.else.526 ] + %bp = phi { ptr, i64 } [ { ptr @str.827, i64 4 }, %if.then.525 ], [ %callN, %if.else.526 ] ret { ptr, i64 } %bp } @@ -9041,12 +9050,12 @@ if.then.528: ; preds = %entry if.else.529: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.830, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.829, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.832, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.831, i64 7 }, { ptr, i64 } %callN) br label %if.merge.530 if.merge.530: ; preds = %if.else.529, %if.then.528 - %bp = phi { ptr, i64 } [ { ptr @str.828, i64 4 }, %if.then.528 ], [ %callN, %if.else.529 ] + %bp = phi { ptr, i64 } [ { ptr @str.830, i64 4 }, %if.then.528 ], [ %callN, %if.else.529 ] ret { ptr, i64 } %bp } @@ -9069,12 +9078,12 @@ if.then.531: ; preds = %entry if.else.532: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.833, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.832, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.835, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.834, i64 6 }, { ptr, i64 } %callN) br label %if.merge.533 if.merge.533: ; preds = %if.else.532, %if.then.531 - %bp = phi { ptr, i64 } [ { ptr @str.831, i64 4 }, %if.then.531 ], [ %callN, %if.else.532 ] + %bp = phi { ptr, i64 } [ { ptr @str.833, i64 4 }, %if.then.531 ], [ %callN, %if.else.532 ] ret { ptr, i64 } %bp } @@ -9097,12 +9106,12 @@ if.then.534: ; preds = %entry if.else.535: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.836, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.835, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.838, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.837, i64 5 }, { ptr, i64 } %callN) br label %if.merge.536 if.merge.536: ; preds = %if.else.535, %if.then.534 - %bp = phi { ptr, i64 } [ { ptr @str.834, i64 4 }, %if.then.534 ], [ %callN, %if.else.535 ] + %bp = phi { ptr, i64 } [ { ptr @str.836, i64 4 }, %if.then.534 ], [ %callN, %if.else.535 ] ret { ptr, i64 } %bp } @@ -9125,12 +9134,12 @@ if.then.537: ; preds = %entry if.else.538: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.839, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.838, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.841, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.840, i64 4 }, { ptr, i64 } %callN) br label %if.merge.539 if.merge.539: ; preds = %if.else.538, %if.then.537 - %bp = phi { ptr, i64 } [ { ptr @str.837, i64 4 }, %if.then.537 ], [ %callN, %if.else.538 ] + %bp = phi { ptr, i64 } [ { ptr @str.839, i64 4 }, %if.then.537 ], [ %callN, %if.else.538 ] ret { ptr, i64 } %bp } @@ -9153,12 +9162,12 @@ if.then.540: ; preds = %entry if.else.541: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.842, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.841, i64 14 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.844, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.843, i64 14 }, { ptr, i64 } %callN) br label %if.merge.542 if.merge.542: ; preds = %if.else.541, %if.then.540 - %bp = phi { ptr, i64 } [ { ptr @str.840, i64 4 }, %if.then.540 ], [ %callN, %if.else.541 ] + %bp = phi { ptr, i64 } [ { ptr @str.842, i64 4 }, %if.then.540 ], [ %callN, %if.else.541 ] ret { ptr, i64 } %bp } @@ -9181,12 +9190,12 @@ if.then.543: ; preds = %entry if.else.544: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.845, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.844, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.847, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.846, i64 7 }, { ptr, i64 } %callN) br label %if.merge.545 if.merge.545: ; preds = %if.else.544, %if.then.543 - %bp = phi { ptr, i64 } [ { ptr @str.843, i64 4 }, %if.then.543 ], [ %callN, %if.else.544 ] + %bp = phi { ptr, i64 } [ { ptr @str.845, i64 4 }, %if.then.543 ], [ %callN, %if.else.544 ] ret { ptr, i64 } %bp } @@ -9209,12 +9218,12 @@ if.then.546: ; preds = %entry if.else.547: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.848, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.847, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.850, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.849, i64 4 }, { ptr, i64 } %callN) br label %if.merge.548 if.merge.548: ; preds = %if.else.547, %if.then.546 - %bp = phi { ptr, i64 } [ { ptr @str.846, i64 4 }, %if.then.546 ], [ %callN, %if.else.547 ] + %bp = phi { ptr, i64 } [ { ptr @str.848, i64 4 }, %if.then.546 ], [ %callN, %if.else.547 ] ret { ptr, i64 } %bp } @@ -9237,12 +9246,12 @@ if.then.549: ; preds = %entry if.else.550: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.851, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.850, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.853, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.852, i64 4 }, { ptr, i64 } %callN) br label %if.merge.551 if.merge.551: ; preds = %if.else.550, %if.then.549 - %bp = phi { ptr, i64 } [ { ptr @str.849, i64 4 }, %if.then.549 ], [ %callN, %if.else.550 ] + %bp = phi { ptr, i64 } [ { ptr @str.851, i64 4 }, %if.then.549 ], [ %callN, %if.else.550 ] ret { ptr, i64 } %bp } @@ -9265,12 +9274,12 @@ if.then.552: ; preds = %entry if.else.553: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.854, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.853, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.856, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.855, i64 8 }, { ptr, i64 } %callN) br label %if.merge.554 if.merge.554: ; preds = %if.else.553, %if.then.552 - %bp = phi { ptr, i64 } [ { ptr @str.852, i64 4 }, %if.then.552 ], [ %callN, %if.else.553 ] + %bp = phi { ptr, i64 } [ { ptr @str.854, i64 4 }, %if.then.552 ], [ %callN, %if.else.553 ] ret { ptr, i64 } %bp } @@ -9286,7 +9295,7 @@ entry: br i1 %lnot, label %if.then.561, label %if.merge.562 if.then.561: ; preds = %entry - ret { ptr, i64 } { ptr @str.855, i64 4 } + ret { ptr, i64 } { ptr @str.857, i64 4 } if.merge.562: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -9310,7 +9319,7 @@ entry: br i1 %lnot, label %if.then.563, label %if.merge.564 if.then.563: ; preds = %entry - ret { ptr, i64 } { ptr @str.856, i64 4 } + ret { ptr, i64 } { ptr @str.858, i64 4 } if.merge.564: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -9334,7 +9343,7 @@ entry: br i1 %lnot, label %if.then.565, label %if.merge.566 if.then.565: ; preds = %entry - ret { ptr, i64 } { ptr @str.857, i64 4 } + ret { ptr, i64 } { ptr @str.859, i64 4 } if.merge.566: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9358,7 +9367,7 @@ entry: br i1 %lnot, label %if.then.567, label %if.merge.568 if.then.567: ; preds = %entry - ret { ptr, i64 } { ptr @str.858, i64 4 } + ret { ptr, i64 } { ptr @str.860, i64 4 } if.merge.568: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0301-closures-fn-pointers.ir b/examples/expected/0301-closures-fn-pointers.ir index 9403593..22ab413 100644 --- a/examples/expected/0301-closures-fn-pointers.ir +++ b/examples/expected/0301-closures-fn-pointers.ir @@ -1,616 +1,616 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [162 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [18 x i8] c"(s32, s32) -> s32\00" -@tn.str.237 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.238 = private constant [7 x i8] c"**void\00" -@tn.str.239 = private constant [19 x i8] c"*(s32, s32) -> s32\00" -@tn.str.240 = private constant [8 x i8] c"*string\00" -@tn.str.241 = private constant [6 x i8] c"[]Any\00" -@tn.str.242 = private constant [5 x i8] c"*Any\00" -@tn.str.243 = private constant [7 x i8] c"[1]Any\00" -@tn.str.244 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.245 = private constant [7 x i8] c"*[]Any\00" -@tn.str.246 = private constant [6 x i8] c"*bool\00" -@tn.str.247 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.248 = private constant [5 x i8] c"*f64\00" -@tn.str.249 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.250 = private constant [11 x i8] c"*Allocator\00" -@tn.str.251 = private constant [9 x i8] c"*Context\00" -@tn.str.252 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.253 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.254 = private constant [8 x i8] c"*Member\00" -@tn.str.255 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.256 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.257 = private constant [9 x i8] c"*Command\00" -@tn.str.258 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.259 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.260 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.261 = private constant [7 x i8] c"*Value\00" -@tn.str.262 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.263 = private constant [14 x i8] c"*Architecture\00" -@tn.str.264 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.265 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.266 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.267 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.268 = private constant [10 x i8] c"*[]string\00" -@tn.str.269 = private constant [6 x i8] c"*[]u8\00" -@tn.str.270 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.271 = private constant [11 x i8] c"*[]Command\00" -@tn.str.272 = private constant [6 x i8] c"**GPA\00" -@tn.str.273 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.274 = private constant [8 x i8] c"**Arena\00" -@tn.str.275 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.276 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.277 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.278 = private constant [7 x i8] c"**File\00" -@tn.str.279 = private constant [5 x i8] c"**u8\00" -@tn.str.280 = private constant [6 x i8] c"**s32\00" -@tn.str.281 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.282 = private constant [6 x i8] c"**u32\00" -@tn.str.283 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.284 = private constant [8 x i8] c"**Array\00" -@tn.str.285 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.286 = private constant [9 x i8] c"**Object\00" -@tn.str.287 = private constant [7 x i8] c"**Sink\00" -@tn.str.288 = private constant [9 x i8] c"**Parser\00" -@tn.str.289 = private constant [6 x i8] c"**s64\00" -@tn.str.290 = private constant [9 x i8] c"**Parsed\00" -@tn.str.291 = private constant [7 x i8] c"**Diag\00" -@tn.str.292 = private constant [9 x i8] c"**Sha256\00" -@tn.str.293 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.294 = private constant [8 x i8] c"***void\00" -@tn.str.295 = private constant [20 x i8] c"**(s32, s32) -> s32\00" -@tn.str.296 = private constant [9 x i8] c"**string\00" -@tn.str.297 = private constant [6 x i8] c"**Any\00" -@tn.str.298 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.299 = private constant [8 x i8] c"**[]Any\00" -@tn.str.300 = private constant [7 x i8] c"**bool\00" -@tn.str.301 = private constant [7 x i8] c"*?File\00" -@tn.str.302 = private constant [9 x i8] c"*?string\00" -@tn.str.303 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.304 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 17 }, { ptr, i64 } { ptr @tn.str.237, i64 12 }, { ptr, i64 } { ptr @tn.str.238, i64 6 }, { ptr, i64 } { ptr @tn.str.239, i64 18 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 5 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 16 }, { ptr, i64 } { ptr @tn.str.250, i64 10 }, { ptr, i64 } { ptr @tn.str.251, i64 8 }, { ptr, i64 } { ptr @tn.str.252, i64 11 }, { ptr, i64 } { ptr @tn.str.253, i64 14 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 13 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 6 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 5 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 12 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 19 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 4 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 10 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 13 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 19 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 5 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 7 }, { ptr, i64 } { ptr @tn.str.300, i64 6 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 15 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }] -@str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [18 x i8] c"(s32, s32) -> s32\00" +@tn.str.239 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.240 = private constant [7 x i8] c"**void\00" +@tn.str.241 = private constant [19 x i8] c"*(s32, s32) -> s32\00" +@tn.str.242 = private constant [8 x i8] c"*string\00" +@tn.str.243 = private constant [6 x i8] c"[]Any\00" +@tn.str.244 = private constant [5 x i8] c"*Any\00" +@tn.str.245 = private constant [7 x i8] c"[1]Any\00" +@tn.str.246 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.247 = private constant [7 x i8] c"*[]Any\00" +@tn.str.248 = private constant [6 x i8] c"*bool\00" +@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.250 = private constant [5 x i8] c"*f64\00" +@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.252 = private constant [11 x i8] c"*Allocator\00" +@tn.str.253 = private constant [9 x i8] c"*Context\00" +@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.256 = private constant [8 x i8] c"*Member\00" +@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.259 = private constant [9 x i8] c"*Command\00" +@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.263 = private constant [7 x i8] c"*Value\00" +@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.265 = private constant [14 x i8] c"*Architecture\00" +@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.270 = private constant [10 x i8] c"*[]string\00" +@tn.str.271 = private constant [6 x i8] c"*[]u8\00" +@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.273 = private constant [11 x i8] c"*[]Command\00" +@tn.str.274 = private constant [6 x i8] c"**GPA\00" +@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.276 = private constant [8 x i8] c"**Arena\00" +@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.280 = private constant [7 x i8] c"**File\00" +@tn.str.281 = private constant [5 x i8] c"**u8\00" +@tn.str.282 = private constant [6 x i8] c"**s32\00" +@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.284 = private constant [6 x i8] c"**u32\00" +@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.286 = private constant [8 x i8] c"**Array\00" +@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.288 = private constant [9 x i8] c"**Object\00" +@tn.str.289 = private constant [7 x i8] c"**Sink\00" +@tn.str.290 = private constant [9 x i8] c"**Parser\00" +@tn.str.291 = private constant [6 x i8] c"**s64\00" +@tn.str.292 = private constant [9 x i8] c"**Parsed\00" +@tn.str.293 = private constant [7 x i8] c"**Diag\00" +@tn.str.294 = private constant [9 x i8] c"**Sha256\00" +@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.296 = private constant [8 x i8] c"***void\00" +@tn.str.297 = private constant [20 x i8] c"**(s32, s32) -> s32\00" +@tn.str.298 = private constant [9 x i8] c"**string\00" +@tn.str.299 = private constant [6 x i8] c"**Any\00" +@tn.str.300 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.301 = private constant [8 x i8] c"**[]Any\00" +@tn.str.302 = private constant [7 x i8] c"**bool\00" +@tn.str.303 = private constant [7 x i8] c"*?File\00" +@tn.str.304 = private constant [9 x i8] c"*?string\00" +@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 17 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 18 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 5 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 19 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 7 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }] @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.311 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.312 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.313 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.314 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.315 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.316 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.326 = private unnamed_addr constant [14 x i8] c"fp(3,4) = {}\0A\00", align 1 -@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.313 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.314 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.315 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.316 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.317 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.318 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.328 = private unnamed_addr constant [14 x i8] c"fp(3,4) = {}\0A\00", align 1 -@str.329 = private unnamed_addr constant [21 x i8] c"apply(add,5,6) = {}\0A\00", align 1 -@str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [14 x i8] c"fp(3,4) = {}\0A\00", align 1 @str.331 = private unnamed_addr constant [21 x i8] c"apply(add,5,6) = {}\0A\00", align 1 -@str.332 = private unnamed_addr constant [21 x i8] c"apply(mul,5,6) = {}\0A\00", align 1 -@str.333 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.333 = private unnamed_addr constant [21 x i8] c"apply(add,5,6) = {}\0A\00", align 1 @str.334 = private unnamed_addr constant [21 x i8] c"apply(mul,5,6) = {}\0A\00", align 1 -@str.335 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.336 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.337 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.338 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.335 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.336 = private unnamed_addr constant [21 x i8] c"apply(mul,5,6) = {}\0A\00", align 1 +@str.337 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.338 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.339 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.339 = private constant [5 x i8] c"line\00" -@fld.str.340 = private constant [4 x i8] c"col\00" -@fld.str.341 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.339, i64 4 }, { ptr, i64 } { ptr @fld.str.340, i64 3 }, { ptr, i64 } { ptr @fld.str.341, i64 4 }] -@str.342 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.343 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.347 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.348 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.349 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.350 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.352 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.353 = private constant [12 x i8] c"alloc_count\00" -@field_names.354 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.353, i64 11 }] -@str.355 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.356 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.357 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.359 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.360 = private constant [5 x i8] c"next\00" -@fld.str.361 = private constant [4 x i8] c"cap\00" -@field_names.362 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.360, i64 4 }, { ptr, i64 } { ptr @fld.str.361, i64 3 }] -@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.364 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.367 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.368 = private constant [4 x i8] c"ctx\00" -@fld.str.369 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.370 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.371 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 3 }, { ptr, i64 } { ptr @fld.str.369, i64 11 }, { ptr, i64 } { ptr @fld.str.370, i64 13 }] -@str.372 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.373 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.374 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.375 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.376 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.377 = private constant [6 x i8] c"first\00" -@fld.str.378 = private constant [10 x i8] c"end_index\00" -@fld.str.379 = private constant [7 x i8] c"parent\00" -@field_names.380 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.377, i64 5 }, { ptr, i64 } { ptr @fld.str.378, i64 9 }, { ptr, i64 } { ptr @fld.str.379, i64 6 }] -@str.381 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.382 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.383 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.384 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.385 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.386 = private constant [4 x i8] c"buf\00" -@fld.str.387 = private constant [4 x i8] c"len\00" -@fld.str.388 = private constant [4 x i8] c"pos\00" -@field_names.389 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.386, i64 3 }, { ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }] -@str.390 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.391 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.392 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.393 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.394 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.395 = private constant [7 x i8] c"parent\00" -@fld.str.396 = private constant [12 x i8] c"alloc_count\00" -@fld.str.397 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.398 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.399 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.395, i64 6 }, { ptr, i64 } { ptr @fld.str.396, i64 11 }, { ptr, i64 } { ptr @fld.str.397, i64 13 }, { ptr, i64 } { ptr @fld.str.398, i64 17 }] -@str.400 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.401 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.402 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.404 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.405 = private constant [10 x i8] c"allocator\00" -@fld.str.406 = private constant [5 x i8] c"data\00" -@field_names.407 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.405, i64 9 }, { ptr, i64 } { ptr @fld.str.406, i64 4 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [3 x i8] c"fd\00" -@field_names.414 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 2 }] -@str.415 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.416 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.417 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.419 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.420 = private constant [5 x i8] c"file\00" -@fld.str.421 = private constant [5 x i8] c"line\00" -@fld.str.422 = private constant [4 x i8] c"col\00" -@fld.str.423 = private constant [5 x i8] c"func\00" -@fld.str.424 = private constant [10 x i8] c"line_text\00" -@field_names.425 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.420, i64 4 }, { ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 3 }, { ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 9 }] -@str.426 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.427 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.428 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.430 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.431 = private constant [10 x i8] c"exit_code\00" -@fld.str.432 = private constant [7 x i8] c"stdout\00" -@field_names.433 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.431, i64 9 }, { ptr, i64 } { ptr @fld.str.432, i64 6 }] -@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.435 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.436 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.438 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.439 = private constant [8 x i8] c"sin_len\00" -@fld.str.440 = private constant [11 x i8] c"sin_family\00" -@fld.str.441 = private constant [9 x i8] c"sin_port\00" -@fld.str.442 = private constant [9 x i8] c"sin_addr\00" -@fld.str.443 = private constant [9 x i8] c"sin_zero\00" -@field_names.444 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 7 }, { ptr, i64 } { ptr @fld.str.440, i64 10 }, { ptr, i64 } { ptr @fld.str.441, i64 8 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }] -@str.445 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.446 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.447 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.449 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.450 = private constant [6 x i8] c"items\00" -@fld.str.451 = private constant [4 x i8] c"len\00" -@fld.str.452 = private constant [4 x i8] c"cap\00" -@field_names.453 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.450, i64 5 }, { ptr, i64 } { ptr @fld.str.451, i64 3 }, { ptr, i64 } { ptr @fld.str.452, i64 3 }] -@str.454 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.455 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.457 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.458 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.459 = private constant [6 x i8] c"items\00" -@fld.str.460 = private constant [4 x i8] c"len\00" -@fld.str.461 = private constant [4 x i8] c"cap\00" -@field_names.462 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.459, i64 5 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }] -@str.463 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.464 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.467 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.468 = private constant [4 x i8] c"key\00" -@fld.str.469 = private constant [4 x i8] c"val\00" -@field_names.470 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.468, i64 3 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }] -@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.472 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.476 = private constant [4 x i8] c"dst\00" -@fld.str.477 = private constant [4 x i8] c"pos\00" -@fld.str.478 = private constant [5 x i8] c"file\00" -@field_names.479 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 4 }] -@str.480 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.481 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.484 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.485 = private constant [4 x i8] c"src\00" -@fld.str.486 = private constant [4 x i8] c"pos\00" -@fld.str.487 = private constant [6 x i8] c"alloc\00" -@field_names.488 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 5 }] -@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.490 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.494 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.495 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.496 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.497 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.499 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.500 = private constant [5 x i8] c"name\00" -@fld.str.501 = private constant [12 x i8] c"takes_value\00" -@fld.str.502 = private constant [9 x i8] c"required\00" -@field_names.503 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.500, i64 4 }, { ptr, i64 } { ptr @fld.str.501, i64 11 }, { ptr, i64 } { ptr @fld.str.502, i64 8 }] -@str.504 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.505 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.508 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.509 = private constant [6 x i8] c"group\00" -@fld.str.510 = private constant [8 x i8] c"command\00" -@fld.str.511 = private constant [6 x i8] c"flags\00" -@field_names.512 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.509, i64 5 }, { ptr, i64 } { ptr @fld.str.510, i64 7 }, { ptr, i64 } { ptr @fld.str.511, i64 5 }] -@str.513 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.514 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.515 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.516 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.517 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.518 = private constant [4 x i8] c"set\00" -@fld.str.519 = private constant [6 x i8] c"value\00" -@field_names.520 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.518, i64 3 }, { ptr, i64 } { ptr @fld.str.519, i64 5 }] -@str.521 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.522 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.523 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.525 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.526 = private constant [6 x i8] c"index\00" -@fld.str.527 = private constant [6 x i8] c"token\00" -@field_names.528 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.526, i64 5 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] -@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.530 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.534 = private constant [6 x i8] c"group\00" -@fld.str.535 = private constant [8 x i8] c"command\00" -@fld.str.536 = private constant [10 x i8] c"cmd_index\00" -@fld.str.537 = private constant [5 x i8] c"json\00" -@fld.str.538 = private constant [5 x i8] c"rest\00" -@fld.str.539 = private constant [5 x i8] c"spec\00" -@fld.str.540 = private constant [7 x i8] c"values\00" -@field_names.541 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 5 }, { ptr, i64 } { ptr @fld.str.535, i64 7 }, { ptr, i64 } { ptr @fld.str.536, i64 9 }, { ptr, i64 } { ptr @fld.str.537, i64 4 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 6 }] -@str.542 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.543 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.544 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.546 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.547 = private constant [2 x i8] c"h\00" -@fld.str.548 = private constant [4 x i8] c"buf\00" -@fld.str.549 = private constant [8 x i8] c"buf_len\00" -@fld.str.550 = private constant [10 x i8] c"total_len\00" -@field_names.551 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.547, i64 1 }, { ptr, i64 } { ptr @fld.str.548, i64 3 }, { ptr, i64 } { ptr @fld.str.549, i64 7 }, { ptr, i64 } { ptr @fld.str.550, i64 9 }] -@str.552 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.553 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.554 = private constant [5 x i8] c"read\00" -@fld.str.555 = private constant [6 x i8] c"write\00" -@fld.str.556 = private constant [7 x i8] c"append\00" -@fld.str.557 = private constant [11 x i8] c"read_write\00" -@field_names.558 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.554, i64 4 }, { ptr, i64 } { ptr @fld.str.555, i64 5 }, { ptr, i64 } { ptr @fld.str.556, i64 6 }, { ptr, i64 } { ptr @fld.str.557, i64 10 }] -@str.559 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.562 = private constant [4 x i8] c"set\00" -@fld.str.563 = private constant [8 x i8] c"current\00" -@fld.str.564 = private constant [4 x i8] c"end\00" -@field_names.565 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 3 }, { ptr, i64 } { ptr @fld.str.563, i64 7 }, { ptr, i64 } { ptr @fld.str.564, i64 3 }] -@str.566 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.567 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.569 = private constant [6 x i8] c"null_\00" -@fld.str.570 = private constant [6 x i8] c"bool_\00" -@fld.str.571 = private constant [5 x i8] c"int_\00" -@fld.str.572 = private constant [4 x i8] c"str\00" -@fld.str.573 = private constant [6 x i8] c"array\00" -@fld.str.574 = private constant [7 x i8] c"object\00" -@field_names.575 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.569, i64 5 }, { ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 4 }, { ptr, i64 } { ptr @fld.str.572, i64 3 }, { ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 6 }] -@str.576 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.579 = private constant [6 x i8] c"macos\00" -@fld.str.580 = private constant [6 x i8] c"linux\00" -@fld.str.581 = private constant [8 x i8] c"windows\00" -@fld.str.582 = private constant [5 x i8] c"wasm\00" -@fld.str.583 = private constant [4 x i8] c"ios\00" -@fld.str.584 = private constant [8 x i8] c"android\00" -@fld.str.585 = private constant [8 x i8] c"unknown\00" -@field_names.586 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 7 }, { ptr, i64 } { ptr @fld.str.582, i64 4 }, { ptr, i64 } { ptr @fld.str.583, i64 3 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }] -@str.587 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.588 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.590 = private constant [8 x i8] c"aarch64\00" -@fld.str.591 = private constant [7 x i8] c"x86_64\00" -@fld.str.592 = private constant [7 x i8] c"wasm32\00" -@fld.str.593 = private constant [7 x i8] c"wasm64\00" -@fld.str.594 = private constant [8 x i8] c"unknown\00" -@field_names.595 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.590, i64 7 }, { ptr, i64 } { ptr @fld.str.591, i64 6 }, { ptr, i64 } { ptr @fld.str.592, i64 6 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }] -@str.596 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.631 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.632 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.633 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.635 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.638 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.641 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.644 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.647 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.650 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.653 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.656 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.659 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.665 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.671 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.674 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.677 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.680 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.683 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.686 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.692 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [10 x i8] c"*function\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.722 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.341 = private constant [5 x i8] c"line\00" +@fld.str.342 = private constant [4 x i8] c"col\00" +@fld.str.343 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.341, i64 4 }, { ptr, i64 } { ptr @fld.str.342, i64 3 }, { ptr, i64 } { ptr @fld.str.343, i64 4 }] +@str.344 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.345 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.346 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.347 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.348 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.349 = private constant [4 x i8] c"ctx\00" +@fld.str.350 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.351 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.352 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.349, i64 3 }, { ptr, i64 } { ptr @fld.str.350, i64 11 }, { ptr, i64 } { ptr @fld.str.351, i64 13 }] +@str.353 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.354 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.357 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.358 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.359 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.360 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.361 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.363 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.364 = private constant [12 x i8] c"alloc_count\00" +@field_names.365 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.364, i64 11 }] +@str.366 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.367 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.368 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.371 = private constant [5 x i8] c"next\00" +@fld.str.372 = private constant [4 x i8] c"cap\00" +@field_names.373 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.371, i64 4 }, { ptr, i64 } { ptr @fld.str.372, i64 3 }] +@str.374 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.375 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.378 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.379 = private constant [6 x i8] c"first\00" +@fld.str.380 = private constant [10 x i8] c"end_index\00" +@fld.str.381 = private constant [7 x i8] c"parent\00" +@field_names.382 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.379, i64 5 }, { ptr, i64 } { ptr @fld.str.380, i64 9 }, { ptr, i64 } { ptr @fld.str.381, i64 6 }] +@str.383 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.384 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.385 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.386 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.387 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.388 = private constant [4 x i8] c"buf\00" +@fld.str.389 = private constant [4 x i8] c"len\00" +@fld.str.390 = private constant [4 x i8] c"pos\00" +@field_names.391 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.388, i64 3 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 3 }] +@str.392 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.393 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.394 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.395 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.396 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.397 = private constant [7 x i8] c"parent\00" +@fld.str.398 = private constant [12 x i8] c"alloc_count\00" +@fld.str.399 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.400 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.401 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.397, i64 6 }, { ptr, i64 } { ptr @fld.str.398, i64 11 }, { ptr, i64 } { ptr @fld.str.399, i64 13 }, { ptr, i64 } { ptr @fld.str.400, i64 17 }] +@str.402 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.403 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.404 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.405 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.406 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.407 = private constant [10 x i8] c"allocator\00" +@fld.str.408 = private constant [5 x i8] c"data\00" +@field_names.409 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.407, i64 9 }, { ptr, i64 } { ptr @fld.str.408, i64 4 }] +@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.411 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.415 = private constant [3 x i8] c"fd\00" +@field_names.416 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 2 }] +@str.417 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.418 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.419 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.421 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.422 = private constant [5 x i8] c"file\00" +@fld.str.423 = private constant [5 x i8] c"line\00" +@fld.str.424 = private constant [4 x i8] c"col\00" +@fld.str.425 = private constant [5 x i8] c"func\00" +@fld.str.426 = private constant [10 x i8] c"line_text\00" +@field_names.427 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 3 }, { ptr, i64 } { ptr @fld.str.425, i64 4 }, { ptr, i64 } { ptr @fld.str.426, i64 9 }] +@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.429 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.430 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.432 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.433 = private constant [10 x i8] c"exit_code\00" +@fld.str.434 = private constant [7 x i8] c"stdout\00" +@field_names.435 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 9 }, { ptr, i64 } { ptr @fld.str.434, i64 6 }] +@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.437 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.441 = private constant [8 x i8] c"sin_len\00" +@fld.str.442 = private constant [11 x i8] c"sin_family\00" +@fld.str.443 = private constant [9 x i8] c"sin_port\00" +@fld.str.444 = private constant [9 x i8] c"sin_addr\00" +@fld.str.445 = private constant [9 x i8] c"sin_zero\00" +@field_names.446 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 7 }, { ptr, i64 } { ptr @fld.str.442, i64 10 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }] +@str.447 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.448 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.449 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.451 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.452 = private constant [6 x i8] c"items\00" +@fld.str.453 = private constant [4 x i8] c"len\00" +@fld.str.454 = private constant [4 x i8] c"cap\00" +@field_names.455 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.452, i64 5 }, { ptr, i64 } { ptr @fld.str.453, i64 3 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }] +@str.456 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.457 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.459 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.460 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.461 = private constant [6 x i8] c"items\00" +@fld.str.462 = private constant [4 x i8] c"len\00" +@fld.str.463 = private constant [4 x i8] c"cap\00" +@field_names.464 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.461, i64 5 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }] +@str.465 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.466 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.468 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.469 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.470 = private constant [4 x i8] c"key\00" +@fld.str.471 = private constant [4 x i8] c"val\00" +@field_names.472 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.470, i64 3 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }] +@str.473 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.474 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.477 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.478 = private constant [4 x i8] c"dst\00" +@fld.str.479 = private constant [4 x i8] c"pos\00" +@fld.str.480 = private constant [5 x i8] c"file\00" +@field_names.481 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 4 }] +@str.482 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.483 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.486 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.487 = private constant [4 x i8] c"src\00" +@fld.str.488 = private constant [4 x i8] c"pos\00" +@fld.str.489 = private constant [6 x i8] c"alloc\00" +@field_names.490 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 5 }] +@str.491 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.492 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.495 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.496 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.497 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.498 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.499 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.501 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.502 = private constant [5 x i8] c"name\00" +@fld.str.503 = private constant [12 x i8] c"takes_value\00" +@fld.str.504 = private constant [9 x i8] c"required\00" +@field_names.505 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.502, i64 4 }, { ptr, i64 } { ptr @fld.str.503, i64 11 }, { ptr, i64 } { ptr @fld.str.504, i64 8 }] +@str.506 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.507 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.510 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.511 = private constant [6 x i8] c"group\00" +@fld.str.512 = private constant [8 x i8] c"command\00" +@fld.str.513 = private constant [6 x i8] c"flags\00" +@field_names.514 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.511, i64 5 }, { ptr, i64 } { ptr @fld.str.512, i64 7 }, { ptr, i64 } { ptr @fld.str.513, i64 5 }] +@str.515 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.516 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.517 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.518 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.519 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.520 = private constant [4 x i8] c"set\00" +@fld.str.521 = private constant [6 x i8] c"value\00" +@field_names.522 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.520, i64 3 }, { ptr, i64 } { ptr @fld.str.521, i64 5 }] +@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.524 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.525 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.527 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.528 = private constant [6 x i8] c"index\00" +@fld.str.529 = private constant [6 x i8] c"token\00" +@field_names.530 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.528, i64 5 }, { ptr, i64 } { ptr @fld.str.529, i64 5 }] +@str.531 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.532 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.535 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.536 = private constant [6 x i8] c"group\00" +@fld.str.537 = private constant [8 x i8] c"command\00" +@fld.str.538 = private constant [10 x i8] c"cmd_index\00" +@fld.str.539 = private constant [5 x i8] c"json\00" +@fld.str.540 = private constant [5 x i8] c"rest\00" +@fld.str.541 = private constant [5 x i8] c"spec\00" +@fld.str.542 = private constant [7 x i8] c"values\00" +@field_names.543 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.536, i64 5 }, { ptr, i64 } { ptr @fld.str.537, i64 7 }, { ptr, i64 } { ptr @fld.str.538, i64 9 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 6 }] +@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.545 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.546 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.548 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.549 = private constant [2 x i8] c"h\00" +@fld.str.550 = private constant [4 x i8] c"buf\00" +@fld.str.551 = private constant [8 x i8] c"buf_len\00" +@fld.str.552 = private constant [10 x i8] c"total_len\00" +@field_names.553 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.549, i64 1 }, { ptr, i64 } { ptr @fld.str.550, i64 3 }, { ptr, i64 } { ptr @fld.str.551, i64 7 }, { ptr, i64 } { ptr @fld.str.552, i64 9 }] +@str.554 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.555 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.556 = private constant [5 x i8] c"read\00" +@fld.str.557 = private constant [6 x i8] c"write\00" +@fld.str.558 = private constant [7 x i8] c"append\00" +@fld.str.559 = private constant [11 x i8] c"read_write\00" +@field_names.560 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 4 }, { ptr, i64 } { ptr @fld.str.557, i64 5 }, { ptr, i64 } { ptr @fld.str.558, i64 6 }, { ptr, i64 } { ptr @fld.str.559, i64 10 }] +@str.561 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.564 = private constant [4 x i8] c"set\00" +@fld.str.565 = private constant [8 x i8] c"current\00" +@fld.str.566 = private constant [4 x i8] c"end\00" +@field_names.567 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 3 }, { ptr, i64 } { ptr @fld.str.565, i64 7 }, { ptr, i64 } { ptr @fld.str.566, i64 3 }] +@str.568 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.569 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.571 = private constant [6 x i8] c"null_\00" +@fld.str.572 = private constant [6 x i8] c"bool_\00" +@fld.str.573 = private constant [5 x i8] c"int_\00" +@fld.str.574 = private constant [4 x i8] c"str\00" +@fld.str.575 = private constant [6 x i8] c"array\00" +@fld.str.576 = private constant [7 x i8] c"object\00" +@field_names.577 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 4 }, { ptr, i64 } { ptr @fld.str.574, i64 3 }, { ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 6 }] +@str.578 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.581 = private constant [6 x i8] c"macos\00" +@fld.str.582 = private constant [6 x i8] c"linux\00" +@fld.str.583 = private constant [8 x i8] c"windows\00" +@fld.str.584 = private constant [5 x i8] c"wasm\00" +@fld.str.585 = private constant [4 x i8] c"ios\00" +@fld.str.586 = private constant [8 x i8] c"android\00" +@fld.str.587 = private constant [8 x i8] c"unknown\00" +@field_names.588 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 5 }, { ptr, i64 } { ptr @fld.str.583, i64 7 }, { ptr, i64 } { ptr @fld.str.584, i64 4 }, { ptr, i64 } { ptr @fld.str.585, i64 3 }, { ptr, i64 } { ptr @fld.str.586, i64 7 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }] +@str.589 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.590 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.592 = private constant [8 x i8] c"aarch64\00" +@fld.str.593 = private constant [7 x i8] c"x86_64\00" +@fld.str.594 = private constant [7 x i8] c"wasm32\00" +@fld.str.595 = private constant [7 x i8] c"wasm64\00" +@fld.str.596 = private constant [8 x i8] c"unknown\00" +@field_names.597 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 7 }] +@str.598 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.602 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.603 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.605 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.633 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.634 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.635 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.636 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.637 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.638 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.640 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.643 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.646 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.649 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.652 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.655 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.658 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.661 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.667 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.673 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.676 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.679 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.682 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.688 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.694 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [10 x i8] c"*function\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.721 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.724 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -623,6 +623,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -842,7 +845,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -969,7 +972,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1303,7 +1306,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1453,7 +1456,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1479,9 +1482,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1522,9 +1525,9 @@ entry: i64 85, label %match.arm.48 i64 98, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1564,7 +1567,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1608,9 +1611,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1691,9 +1694,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.334 [ i64 18, label %dispatch.case.335 - i64 21, label %dispatch.case.336 - i64 23, label %dispatch.case.337 - i64 25, label %dispatch.case.338 + i64 22, label %dispatch.case.336 + i64 24, label %dispatch.case.337 + i64 26, label %dispatch.case.338 i64 28, label %dispatch.case.339 i64 29, label %dispatch.case.340 i64 31, label %dispatch.case.341 @@ -1791,7 +1794,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1805,32 +1808,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2000,7 +2003,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2041,7 +2044,7 @@ dispatch.merge.263: ; preds = %dispatch.case.270, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2098,7 +2101,7 @@ dispatch.merge.301: ; preds = %dispatch.case.307, br label %match.merge.37 dispatch.default.302: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.301 dispatch.case.303: ; preds = %match.arm.48 @@ -2147,7 +2150,7 @@ dispatch.merge.333: ; preds = %dispatch.case.365, br label %match.merge.37 dispatch.default.334: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.49 @@ -2373,7 +2376,7 @@ dispatch.merge.472: ; preds = %dispatch.case.477, br label %match.merge.37 dispatch.default.473: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.472 dispatch.case.474: ; preds = %match.arm.50 @@ -2415,7 +2418,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.311, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2511,7 +2514,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2519,7 +2522,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2529,13 +2532,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2543,7 +2546,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2557,7 +2560,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2565,7 +2568,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2576,7 +2579,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2633,7 +2636,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2641,7 +2644,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2652,7 +2655,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2672,7 +2675,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2680,7 +2683,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, 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 @@ -2691,7 +2694,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2701,64 +2704,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2934,163 +2940,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3288,64 +3297,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3375,97 +3384,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3504,7 +3513,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @add(ptr %0, i32 %1, i32 %2) #0 { @@ -3585,7 +3594,7 @@ entry: define internal void @print__ct_sab6a3b1f9bc359ad__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.326, i64 13 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.328, i64 13 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3601,7 +3610,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 10) @@ -3629,7 +3638,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.328, i64 13 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.330, i64 13 }) ret { ptr, i64 } %call } @@ -3637,7 +3646,7 @@ entry: define internal void @print__ct_s3417a75739024851__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.329, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.331, i64 20 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3653,7 +3662,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 17) @@ -3681,7 +3690,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.331, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.333, i64 20 }) ret { ptr, i64 } %call } @@ -3689,7 +3698,7 @@ entry: define internal void @print__ct_s2ed9f416bd1dfc65__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.332, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.334, i64 20 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3705,7 +3714,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 17) @@ -3733,7 +3742,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.334, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.336, i64 20 }) ret { ptr, i64 } %call } @@ -3744,7 +3753,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.335, i64 15 }, { ptr, i64 } { ptr @str.336, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.337, i64 15 }, { ptr, i64 } { ptr @str.338, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3763,12 +3772,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3780,7 +3789,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3833,20 +3842,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 10 }, { ptr, i64 } { ptr @str.344, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.345, i64 9 }, { ptr, i64 } { ptr @str.346, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3856,224 +3865,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.347, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.352, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.349, i64 3 }, { ptr, i64 } { ptr @str.350, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.354, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.356, i64 10 }, { ptr, i64 } { ptr @str.357, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.362, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.364, i64 9 }, { ptr, i64 } { ptr @str.365, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.371, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, 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 @@ -4092,27 +3901,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.354, i64 10 }, { ptr, i64 } { ptr @str.355, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.358, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.360, i64 3 }, { ptr, i64 } { ptr @str.361, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.365, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.367, i64 10 }, { ptr, i64 } { ptr @str.368, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.373, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4122,7 +4131,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.373, i64 5 }, { ptr, i64 } { ptr @str.374, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.375, i64 5 }, { ptr, i64 } { ptr @str.376, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4141,24 +4150,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.380, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.382, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, 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 @@ -4185,7 +4194,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4197,7 +4206,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4206,7 +4215,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.382, i64 8 }, { ptr, i64 } { ptr @str.383, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.384, i64 8 }, { ptr, i64 } { ptr @str.385, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4225,24 +4234,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.389, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.391, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, 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 @@ -4289,7 +4298,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.391, i64 17 }, { ptr, i64 } { ptr @str.392, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.393, i64 17 }, { ptr, i64 } { ptr @str.394, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4308,24 +4317,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.399, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.401, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4354,7 +4363,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4379,7 +4388,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.401, i64 7 }, { ptr, i64 } { ptr @str.402, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.403, i64 7 }, { ptr, i64 } { ptr @str.404, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4398,24 +4407,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.407, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, 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 @@ -4442,7 +4451,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4457,7 +4466,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 4 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 4 }, { ptr, i64 } { ptr @str.412, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4476,24 +4485,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.414, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.416, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4530,7 +4539,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.416, i64 10 }, { ptr, i64 } { ptr @str.417, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.418, i64 10 }, { ptr, i64 } { ptr @str.419, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4549,24 +4558,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.425, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.427, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4632,7 +4641,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.427, i64 13 }, { ptr, i64 } { ptr @str.428, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 13 }, { ptr, i64 } { ptr @str.430, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4651,24 +4660,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.433, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4710,7 +4719,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 8 }, { ptr, i64 } { ptr @str.436, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 8 }, { ptr, i64 } { ptr @str.438, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4729,24 +4738,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.444, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.446, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4807,7 +4816,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.446, i64 5 }, { ptr, i64 } { ptr @str.447, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.448, i64 5 }, { ptr, i64 } { ptr @str.449, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4826,24 +4835,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.453, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.455, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, 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 @@ -4889,7 +4898,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.455, i64 6 }, { ptr, i64 } { ptr @str.456, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.457, i64 6 }, { ptr, i64 } { ptr @str.458, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4908,24 +4917,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.462, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.464, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, 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 @@ -4973,7 +4982,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.464, i64 6 }, { ptr, i64 } { ptr @str.465, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.466, i64 6 }, { ptr, i64 } { ptr @str.467, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4992,24 +5001,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.470, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.472, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5053,7 +5062,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 4 }, { ptr, i64 } { ptr @str.473, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.474, i64 4 }, { ptr, i64 } { ptr @str.475, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5072,24 +5081,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.479, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.481, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5139,7 +5148,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.481, i64 6 }, { ptr, i64 } { ptr @str.482, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.483, i64 6 }, { ptr, i64 } { ptr @str.484, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5158,24 +5167,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.488, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.490, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5215,7 +5224,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5224,7 +5233,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 12 }, { ptr, i64 } { ptr @str.491, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.492, i64 12 }, { ptr, i64 } { ptr @str.493, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5243,24 +5252,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.494, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.496, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5280,7 +5289,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.496, i64 8 }, { ptr, i64 } { ptr @str.497, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.498, i64 8 }, { ptr, i64 } { ptr @str.499, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5299,24 +5308,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.503, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.505, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5368,7 +5377,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.505, i64 7 }, { ptr, i64 } { ptr @str.506, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.507, i64 7 }, { ptr, i64 } { ptr @str.508, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5387,24 +5396,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.512, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.514, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5456,7 +5465,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.514, i64 9 }, { ptr, i64 } { ptr @str.515, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.516, i64 9 }, { ptr, i64 } { ptr @str.517, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5475,24 +5484,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.520, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.522, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5535,7 +5544,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.522, i64 4 }, { ptr, i64 } { ptr @str.523, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 4 }, { ptr, i64 } { ptr @str.525, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5554,24 +5563,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.528, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.530, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5617,7 +5626,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 6 }, { ptr, i64 } { ptr @str.531, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.532, i64 6 }, { ptr, i64 } { ptr @str.533, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5636,24 +5645,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.541, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.543, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5735,7 +5744,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.543, i64 6 }, { ptr, i64 } { ptr @str.544, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 6 }, { ptr, i64 } { ptr @str.546, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5754,24 +5763,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.551, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.553, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5830,9 +5839,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.558, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.560, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, 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 @@ -5851,8 +5860,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5871,9 +5880,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.565, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.567, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, 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 @@ -5892,8 +5901,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.567, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.566, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.568, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5923,9 +5932,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.577, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.568, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.570, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5942,8 +5951,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -6021,9 +6030,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.586, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.588, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.580, 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 @@ -6042,8 +6051,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.587, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.589, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -6062,9 +6071,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.595, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.597, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.589, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.591, 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 @@ -6083,8 +6092,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.596, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6101,7 +6110,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.598, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.600, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.271 @@ -6118,12 +6127,12 @@ while.body.272: ; preds = %while.hdr.271 while.exit.273: ; preds = %while.hdr.271 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 1 }) ret { ptr, i64 } %call if.then.274: ; preds = %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.275 @@ -6152,7 +6161,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.603, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -6169,12 +6178,12 @@ while.body.277: ; preds = %while.hdr.276 while.exit.278: ; preds = %while.hdr.276 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 1 }) ret { ptr, i64 } %call if.then.279: ; preds = %while.body.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6204,7 +6213,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6221,12 +6230,12 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %call if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -6254,7 +6263,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6271,12 +6280,12 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %call if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6305,7 +6314,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6322,12 +6331,12 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %call if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -6356,7 +6365,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6373,12 +6382,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6408,7 +6417,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.308 @@ -6427,12 +6436,12 @@ while.body.309: ; preds = %while.hdr.308 while.exit.310: ; preds = %while.hdr.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) ret { ptr, i64 } %call if.then.311: ; preds = %while.body.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.312 @@ -6461,7 +6470,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6480,12 +6489,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6514,7 +6523,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6533,12 +6542,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6568,7 +6577,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6587,12 +6596,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6622,7 +6631,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6641,12 +6650,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6688,12 +6697,12 @@ if.then.366: ; preds = %entry if.else.367: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 5 }, { ptr, i64 } %callN) br label %if.merge.368 if.merge.368: ; preds = %if.else.367, %if.then.366 - %bp = phi { ptr, i64 } [ { ptr @str.631, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.633, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6716,12 +6725,12 @@ if.then.382: ; preds = %entry if.else.383: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 11 }, { ptr, i64 } %callN) br label %if.merge.384 if.merge.384: ; preds = %if.else.383, %if.then.382 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6744,12 +6753,12 @@ if.then.385: ; preds = %entry if.else.386: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 4 }, { ptr, i64 } %callN) br label %if.merge.387 if.merge.387: ; preds = %if.else.386, %if.then.385 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6772,12 +6781,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6800,12 +6809,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 6 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6827,12 +6836,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 5 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6855,12 +6864,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 9 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6883,12 +6892,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 18 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6911,12 +6920,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 5 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6939,12 +6948,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6967,12 +6976,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 4 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6995,12 +7004,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 9 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -7023,12 +7032,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -7050,12 +7059,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 8 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7078,12 +7087,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 6 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7105,12 +7114,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 9 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7133,12 +7142,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 7 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7161,12 +7170,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 5 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7189,12 +7198,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7217,12 +7226,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 4 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7245,12 +7254,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7273,12 +7282,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 5 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7301,12 +7310,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7329,12 +7338,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 12 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7357,12 +7366,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 6 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7385,12 +7394,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 9 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7413,12 +7422,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 7 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7441,12 +7450,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 4 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7469,12 +7478,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7497,12 +7506,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 6 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7525,12 +7534,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 5 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7546,7 +7555,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.724, i64 4 } + ret { ptr, i64 } { ptr @str.726, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7570,7 +7579,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.725, i64 4 } + ret { ptr, i64 } { ptr @str.727, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7594,7 +7603,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.726, i64 4 } + ret { ptr, i64 } { ptr @str.728, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7618,7 +7627,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.485: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0400-protocols-impl-for-builtin.ir b/examples/expected/0400-protocols-impl-for-builtin.ir index 32815d1..521a1a4 100644 --- a/examples/expected/0400-protocols-impl-for-builtin.ir +++ b/examples/expected/0400-protocols-impl-for-builtin.ir @@ -1,630 +1,630 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [165 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [9 x i8] c"Lerpable\00" -@tn.str.163 = private constant [16 x i8] c"Source_Location\00" -@tn.str.164 = private constant [11 x i8] c"CAllocator\00" -@tn.str.165 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.166 = private constant [4 x i8] c"GPA\00" -@tn.str.167 = private constant [5 x i8] c"*GPA\00" -@tn.str.168 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.169 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.170 = private constant [10 x i8] c"Allocator\00" -@tn.str.171 = private constant [6 x i8] c"Arena\00" -@tn.str.172 = private constant [7 x i8] c"*Arena\00" -@tn.str.173 = private constant [6 x i8] c"[*]u8\00" -@tn.str.174 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.175 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.176 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.177 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.178 = private constant [8 x i8] c"Context\00" -@tn.str.179 = private constant [7 x i8] c"[4]s64\00" -@tn.str.180 = private constant [9 x i8] c"[]string\00" -@tn.str.181 = private constant [9 x i8] c"OpenMode\00" -@tn.str.182 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.183 = private constant [5 x i8] c"File\00" -@tn.str.184 = private constant [6 x i8] c"*File\00" -@tn.str.185 = private constant [6 x i8] c"?File\00" -@tn.str.186 = private constant [8 x i8] c"?string\00" -@tn.str.187 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.188 = private constant [4 x i8] c"*u8\00" -@tn.str.189 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.190 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.191 = private constant [5 x i8] c"*s32\00" -@tn.str.192 = private constant [9 x i8] c"SockAddr\00" -@tn.str.193 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.194 = private constant [5 x i8] c"*u32\00" -@tn.str.195 = private constant [10 x i8] c"JsonError\00" -@tn.str.196 = private constant [6 x i8] c"Array\00" -@tn.str.197 = private constant [7 x i8] c"Object\00" -@tn.str.198 = private constant [6 x i8] c"Value\00" -@tn.str.199 = private constant [7 x i8] c"Member\00" -@tn.str.200 = private constant [9 x i8] c"[*]Value\00" -@tn.str.201 = private constant [7 x i8] c"*Array\00" -@tn.str.202 = private constant [10 x i8] c"[*]Member\00" -@tn.str.203 = private constant [8 x i8] c"*Object\00" -@tn.str.204 = private constant [5 x i8] c"[]u8\00" -@tn.str.205 = private constant [5 x i8] c"Sink\00" -@tn.str.206 = private constant [6 x i8] c"*Sink\00" -@tn.str.207 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.208 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.209 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.210 = private constant [7 x i8] c"Parser\00" -@tn.str.211 = private constant [8 x i8] c"*Parser\00" -@tn.str.212 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.213 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.214 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.215 = private constant [13 x i8] c"Architecture\00" -@tn.str.216 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.217 = private constant [11 x i8] c"() -> bool\00" -@tn.str.218 = private constant [5 x i8] c"*s64\00" -@tn.str.219 = private constant [9 x i8] c"CliError\00" -@tn.str.220 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.221 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.222 = private constant [8 x i8] c"Command\00" -@tn.str.223 = private constant [10 x i8] c"FlagValue\00" -@tn.str.224 = private constant [5 x i8] c"Diag\00" -@tn.str.225 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.226 = private constant [7 x i8] c"Parsed\00" -@tn.str.227 = private constant [8 x i8] c"*Parsed\00" -@tn.str.228 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.229 = private constant [10 x i8] c"[]Command\00" -@tn.str.230 = private constant [6 x i8] c"*Diag\00" -@tn.str.231 = private constant [7 x i8] c"[8]s64\00" -@tn.str.232 = private constant [7 x i8] c"[64]u8\00" -@tn.str.233 = private constant [7 x i8] c"Sha256\00" -@tn.str.234 = private constant [8 x i8] c"*Sha256\00" -@tn.str.235 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.236 = private constant [8 x i8] c"[64]s64\00" -@tn.str.237 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.238 = private constant [7 x i8] c"**void\00" -@tn.str.239 = private constant [5 x i8] c"*f32\00" -@tn.str.240 = private constant [8 x i8] c"*string\00" -@tn.str.241 = private constant [6 x i8] c"[]Any\00" -@tn.str.242 = private constant [5 x i8] c"*Any\00" -@tn.str.243 = private constant [7 x i8] c"[1]Any\00" -@tn.str.244 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.245 = private constant [7 x i8] c"*[]Any\00" -@tn.str.246 = private constant [6 x i8] c"*bool\00" -@tn.str.247 = private constant [6 x i8] c"**f32\00" -@tn.str.248 = private constant [10 x i8] c"*Lerpable\00" -@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.250 = private constant [5 x i8] c"*f64\00" -@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.252 = private constant [11 x i8] c"*Allocator\00" -@tn.str.253 = private constant [9 x i8] c"*Context\00" -@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.256 = private constant [8 x i8] c"*Member\00" -@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.259 = private constant [9 x i8] c"*Command\00" -@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.263 = private constant [7 x i8] c"*Value\00" -@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.265 = private constant [14 x i8] c"*Architecture\00" -@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.270 = private constant [10 x i8] c"*[]string\00" -@tn.str.271 = private constant [6 x i8] c"*[]u8\00" -@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.273 = private constant [11 x i8] c"*[]Command\00" -@tn.str.274 = private constant [6 x i8] c"**GPA\00" -@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.276 = private constant [8 x i8] c"**Arena\00" -@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.280 = private constant [7 x i8] c"**File\00" -@tn.str.281 = private constant [5 x i8] c"**u8\00" -@tn.str.282 = private constant [6 x i8] c"**s32\00" -@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.284 = private constant [6 x i8] c"**u32\00" -@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.286 = private constant [8 x i8] c"**Array\00" -@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.288 = private constant [9 x i8] c"**Object\00" -@tn.str.289 = private constant [7 x i8] c"**Sink\00" -@tn.str.290 = private constant [9 x i8] c"**Parser\00" -@tn.str.291 = private constant [6 x i8] c"**s64\00" -@tn.str.292 = private constant [9 x i8] c"**Parsed\00" -@tn.str.293 = private constant [7 x i8] c"**Diag\00" -@tn.str.294 = private constant [9 x i8] c"**Sha256\00" -@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.296 = private constant [8 x i8] c"***void\00" -@tn.str.297 = private constant [9 x i8] c"**string\00" -@tn.str.298 = private constant [6 x i8] c"**Any\00" -@tn.str.299 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.300 = private constant [8 x i8] c"**[]Any\00" -@tn.str.301 = private constant [7 x i8] c"**bool\00" -@tn.str.302 = private constant [7 x i8] c"***f32\00" -@tn.str.303 = private constant [11 x i8] c"**Lerpable\00" -@tn.str.304 = private constant [7 x i8] c"*?File\00" -@tn.str.305 = private constant [9 x i8] c"*?string\00" -@tn.str.306 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.307 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [165 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 8 }, { ptr, i64 } { ptr @tn.str.163, i64 15 }, { ptr, i64 } { ptr @tn.str.164, i64 10 }, { ptr, i64 } { ptr @tn.str.165, i64 11 }, { ptr, i64 } { ptr @tn.str.166, i64 3 }, { ptr, i64 } { ptr @tn.str.167, i64 4 }, { ptr, i64 } { ptr @tn.str.168, i64 10 }, { ptr, i64 } { ptr @tn.str.169, i64 11 }, { ptr, i64 } { ptr @tn.str.170, i64 9 }, { ptr, i64 } { ptr @tn.str.171, i64 5 }, { ptr, i64 } { ptr @tn.str.172, i64 6 }, { ptr, i64 } { ptr @tn.str.173, i64 5 }, { ptr, i64 } { ptr @tn.str.174, i64 8 }, { ptr, i64 } { ptr @tn.str.175, i64 9 }, { ptr, i64 } { ptr @tn.str.176, i64 17 }, { ptr, i64 } { ptr @tn.str.177, i64 18 }, { ptr, i64 } { ptr @tn.str.178, i64 7 }, { ptr, i64 } { ptr @tn.str.179, i64 6 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 4 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 7 }, { ptr, i64 } { ptr @tn.str.187, i64 10 }, { ptr, i64 } { ptr @tn.str.188, i64 3 }, { ptr, i64 } { ptr @tn.str.189, i64 13 }, { ptr, i64 } { ptr @tn.str.190, i64 14 }, { ptr, i64 } { ptr @tn.str.191, i64 4 }, { ptr, i64 } { ptr @tn.str.192, i64 8 }, { ptr, i64 } { ptr @tn.str.193, i64 9 }, { ptr, i64 } { ptr @tn.str.194, i64 4 }, { ptr, i64 } { ptr @tn.str.195, i64 9 }, { ptr, i64 } { ptr @tn.str.196, i64 5 }, { ptr, i64 } { ptr @tn.str.197, i64 6 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 6 }, { ptr, i64 } { ptr @tn.str.200, i64 8 }, { ptr, i64 } { ptr @tn.str.201, i64 6 }, { ptr, i64 } { ptr @tn.str.202, i64 9 }, { ptr, i64 } { ptr @tn.str.203, i64 7 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 5 }, { ptr, i64 } { ptr @tn.str.207, i64 16 }, { ptr, i64 } { ptr @tn.str.208, i64 14 }, { ptr, i64 } { ptr @tn.str.209, i64 21 }, { ptr, i64 } { ptr @tn.str.210, i64 6 }, { ptr, i64 } { ptr @tn.str.211, i64 7 }, { ptr, i64 } { ptr @tn.str.212, i64 24 }, { ptr, i64 } { ptr @tn.str.213, i64 23 }, { ptr, i64 } { ptr @tn.str.214, i64 15 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 10 }, { ptr, i64 } { ptr @tn.str.218, i64 4 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 10 }, { ptr, i64 } { ptr @tn.str.222, i64 7 }, { ptr, i64 } { ptr @tn.str.223, i64 9 }, { ptr, i64 } { ptr @tn.str.224, i64 4 }, { ptr, i64 } { ptr @tn.str.225, i64 13 }, { ptr, i64 } { ptr @tn.str.226, i64 6 }, { ptr, i64 } { ptr @tn.str.227, i64 7 }, { ptr, i64 } { ptr @tn.str.228, i64 18 }, { ptr, i64 } { ptr @tn.str.229, i64 9 }, { ptr, i64 } { ptr @tn.str.230, i64 5 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 12 }, { ptr, i64 } { ptr @tn.str.238, i64 6 }, { ptr, i64 } { ptr @tn.str.239, i64 4 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 5 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 5 }, { ptr, i64 } { ptr @tn.str.248, i64 9 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 10 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 15 }, { ptr, i64 } { ptr @tn.str.307, i64 8 }] -@str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [9 x i8] c"Lerpable\00" +@tn.str.165 = private constant [16 x i8] c"Source_Location\00" +@tn.str.166 = private constant [10 x i8] c"Allocator\00" +@tn.str.167 = private constant [11 x i8] c"CAllocator\00" +@tn.str.168 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.169 = private constant [4 x i8] c"GPA\00" +@tn.str.170 = private constant [5 x i8] c"*GPA\00" +@tn.str.171 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.172 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.173 = private constant [6 x i8] c"Arena\00" +@tn.str.174 = private constant [7 x i8] c"*Arena\00" +@tn.str.175 = private constant [6 x i8] c"[*]u8\00" +@tn.str.176 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.177 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.178 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.179 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.180 = private constant [8 x i8] c"Context\00" +@tn.str.181 = private constant [7 x i8] c"[4]s64\00" +@tn.str.182 = private constant [9 x i8] c"[]string\00" +@tn.str.183 = private constant [9 x i8] c"OpenMode\00" +@tn.str.184 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.185 = private constant [5 x i8] c"File\00" +@tn.str.186 = private constant [6 x i8] c"*File\00" +@tn.str.187 = private constant [6 x i8] c"?File\00" +@tn.str.188 = private constant [8 x i8] c"?string\00" +@tn.str.189 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.190 = private constant [4 x i8] c"*u8\00" +@tn.str.191 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.192 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.193 = private constant [5 x i8] c"*s32\00" +@tn.str.194 = private constant [9 x i8] c"SockAddr\00" +@tn.str.195 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.196 = private constant [5 x i8] c"*u32\00" +@tn.str.197 = private constant [10 x i8] c"JsonError\00" +@tn.str.198 = private constant [6 x i8] c"Array\00" +@tn.str.199 = private constant [7 x i8] c"Object\00" +@tn.str.200 = private constant [6 x i8] c"Value\00" +@tn.str.201 = private constant [7 x i8] c"Member\00" +@tn.str.202 = private constant [9 x i8] c"[*]Value\00" +@tn.str.203 = private constant [7 x i8] c"*Array\00" +@tn.str.204 = private constant [10 x i8] c"[*]Member\00" +@tn.str.205 = private constant [8 x i8] c"*Object\00" +@tn.str.206 = private constant [5 x i8] c"[]u8\00" +@tn.str.207 = private constant [5 x i8] c"Sink\00" +@tn.str.208 = private constant [6 x i8] c"*Sink\00" +@tn.str.209 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.210 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.211 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.212 = private constant [7 x i8] c"Parser\00" +@tn.str.213 = private constant [8 x i8] c"*Parser\00" +@tn.str.214 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.215 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.216 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.217 = private constant [13 x i8] c"Architecture\00" +@tn.str.218 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.219 = private constant [11 x i8] c"() -> bool\00" +@tn.str.220 = private constant [5 x i8] c"*s64\00" +@tn.str.221 = private constant [9 x i8] c"CliError\00" +@tn.str.222 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.223 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.224 = private constant [8 x i8] c"Command\00" +@tn.str.225 = private constant [10 x i8] c"FlagValue\00" +@tn.str.226 = private constant [5 x i8] c"Diag\00" +@tn.str.227 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.228 = private constant [7 x i8] c"Parsed\00" +@tn.str.229 = private constant [8 x i8] c"*Parsed\00" +@tn.str.230 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.231 = private constant [10 x i8] c"[]Command\00" +@tn.str.232 = private constant [6 x i8] c"*Diag\00" +@tn.str.233 = private constant [7 x i8] c"[8]s64\00" +@tn.str.234 = private constant [7 x i8] c"[64]u8\00" +@tn.str.235 = private constant [7 x i8] c"Sha256\00" +@tn.str.236 = private constant [8 x i8] c"*Sha256\00" +@tn.str.237 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.238 = private constant [8 x i8] c"[64]s64\00" +@tn.str.239 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.240 = private constant [7 x i8] c"**void\00" +@tn.str.241 = private constant [5 x i8] c"*f32\00" +@tn.str.242 = private constant [8 x i8] c"*string\00" +@tn.str.243 = private constant [6 x i8] c"[]Any\00" +@tn.str.244 = private constant [5 x i8] c"*Any\00" +@tn.str.245 = private constant [7 x i8] c"[1]Any\00" +@tn.str.246 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.247 = private constant [7 x i8] c"*[]Any\00" +@tn.str.248 = private constant [6 x i8] c"*bool\00" +@tn.str.249 = private constant [6 x i8] c"**f32\00" +@tn.str.250 = private constant [10 x i8] c"*Lerpable\00" +@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.252 = private constant [5 x i8] c"*f64\00" +@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.254 = private constant [11 x i8] c"*Allocator\00" +@tn.str.255 = private constant [9 x i8] c"*Context\00" +@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.258 = private constant [8 x i8] c"*Member\00" +@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.261 = private constant [9 x i8] c"*Command\00" +@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.265 = private constant [7 x i8] c"*Value\00" +@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.267 = private constant [14 x i8] c"*Architecture\00" +@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.272 = private constant [10 x i8] c"*[]string\00" +@tn.str.273 = private constant [6 x i8] c"*[]u8\00" +@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.275 = private constant [11 x i8] c"*[]Command\00" +@tn.str.276 = private constant [6 x i8] c"**GPA\00" +@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.278 = private constant [8 x i8] c"**Arena\00" +@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.282 = private constant [7 x i8] c"**File\00" +@tn.str.283 = private constant [5 x i8] c"**u8\00" +@tn.str.284 = private constant [6 x i8] c"**s32\00" +@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.286 = private constant [6 x i8] c"**u32\00" +@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.288 = private constant [8 x i8] c"**Array\00" +@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.290 = private constant [9 x i8] c"**Object\00" +@tn.str.291 = private constant [7 x i8] c"**Sink\00" +@tn.str.292 = private constant [9 x i8] c"**Parser\00" +@tn.str.293 = private constant [6 x i8] c"**s64\00" +@tn.str.294 = private constant [9 x i8] c"**Parsed\00" +@tn.str.295 = private constant [7 x i8] c"**Diag\00" +@tn.str.296 = private constant [9 x i8] c"**Sha256\00" +@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.298 = private constant [8 x i8] c"***void\00" +@tn.str.299 = private constant [9 x i8] c"**string\00" +@tn.str.300 = private constant [6 x i8] c"**Any\00" +@tn.str.301 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.302 = private constant [8 x i8] c"**[]Any\00" +@tn.str.303 = private constant [7 x i8] c"**bool\00" +@tn.str.304 = private constant [7 x i8] c"***f32\00" +@tn.str.305 = private constant [11 x i8] c"**Lerpable\00" +@tn.str.306 = private constant [7 x i8] c"*?File\00" +@tn.str.307 = private constant [9 x i8] c"*?string\00" +@tn.str.308 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.309 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [165 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 8 }, { ptr, i64 } { ptr @tn.str.165, i64 15 }, { ptr, i64 } { ptr @tn.str.166, i64 9 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 3 }, { ptr, i64 } { ptr @tn.str.170, i64 4 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 5 }, { ptr, i64 } { ptr @tn.str.174, i64 6 }, { ptr, i64 } { ptr @tn.str.175, i64 5 }, { ptr, i64 } { ptr @tn.str.176, i64 8 }, { ptr, i64 } { ptr @tn.str.177, i64 9 }, { ptr, i64 } { ptr @tn.str.178, i64 17 }, { ptr, i64 } { ptr @tn.str.179, i64 18 }, { ptr, i64 } { ptr @tn.str.180, i64 7 }, { ptr, i64 } { ptr @tn.str.181, i64 6 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 8 }, { ptr, i64 } { ptr @tn.str.185, i64 4 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 5 }, { ptr, i64 } { ptr @tn.str.188, i64 7 }, { ptr, i64 } { ptr @tn.str.189, i64 10 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 13 }, { ptr, i64 } { ptr @tn.str.192, i64 14 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 8 }, { ptr, i64 } { ptr @tn.str.195, i64 9 }, { ptr, i64 } { ptr @tn.str.196, i64 4 }, { ptr, i64 } { ptr @tn.str.197, i64 9 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 6 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 6 }, { ptr, i64 } { ptr @tn.str.202, i64 8 }, { ptr, i64 } { ptr @tn.str.203, i64 6 }, { ptr, i64 } { ptr @tn.str.204, i64 9 }, { ptr, i64 } { ptr @tn.str.205, i64 7 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 4 }, { ptr, i64 } { ptr @tn.str.208, i64 5 }, { ptr, i64 } { ptr @tn.str.209, i64 16 }, { ptr, i64 } { ptr @tn.str.210, i64 14 }, { ptr, i64 } { ptr @tn.str.211, i64 21 }, { ptr, i64 } { ptr @tn.str.212, i64 6 }, { ptr, i64 } { ptr @tn.str.213, i64 7 }, { ptr, i64 } { ptr @tn.str.214, i64 24 }, { ptr, i64 } { ptr @tn.str.215, i64 23 }, { ptr, i64 } { ptr @tn.str.216, i64 15 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 12 }, { ptr, i64 } { ptr @tn.str.219, i64 10 }, { ptr, i64 } { ptr @tn.str.220, i64 4 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 10 }, { ptr, i64 } { ptr @tn.str.224, i64 7 }, { ptr, i64 } { ptr @tn.str.225, i64 9 }, { ptr, i64 } { ptr @tn.str.226, i64 4 }, { ptr, i64 } { ptr @tn.str.227, i64 13 }, { ptr, i64 } { ptr @tn.str.228, i64 6 }, { ptr, i64 } { ptr @tn.str.229, i64 7 }, { ptr, i64 } { ptr @tn.str.230, i64 18 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 5 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 5 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 5 }, { ptr, i64 } { ptr @tn.str.250, i64 9 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 10 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 8 }, { ptr, i64 } { ptr @tn.str.308, i64 15 }, { ptr, i64 } { ptr @tn.str.309, i64 8 }] @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.314 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.315 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.316 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.317 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.318 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.319 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.326 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.327 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.328 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.329 = private unnamed_addr constant [23 x i8] c"lerp(0, 10, 0.5) = {}\0A\00", align 1 -@str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.315 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.316 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.320 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.321 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.328 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.329 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.330 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.331 = private unnamed_addr constant [23 x i8] c"lerp(0, 10, 0.5) = {}\0A\00", align 1 -@str.332 = private unnamed_addr constant [24 x i8] c"lerp(0, 10, 0.25) = {}\0A\00", align 1 -@str.333 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.333 = private unnamed_addr constant [23 x i8] c"lerp(0, 10, 0.5) = {}\0A\00", align 1 @str.334 = private unnamed_addr constant [24 x i8] c"lerp(0, 10, 0.25) = {}\0A\00", align 1 -@str.335 = private unnamed_addr constant [9 x i8] c"Lerpable\00", align 1 -@str.336 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.337 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.338 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.335 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.336 = private unnamed_addr constant [24 x i8] c"lerp(0, 10, 0.25) = {}\0A\00", align 1 +@str.337 = private unnamed_addr constant [9 x i8] c"Lerpable\00", align 1 +@str.338 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.339 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [4 x i8] c"ctx\00" -@fld.str.339 = private constant [5 x i8] c"lerp\00" -@field_names = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 3 }, { ptr, i64 } { ptr @fld.str.339, i64 4 }] -@str.340 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.341 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.342 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.343 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.344 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.345 = private constant [5 x i8] c"file\00" -@fld.str.346 = private constant [5 x i8] c"line\00" -@fld.str.347 = private constant [4 x i8] c"col\00" -@fld.str.348 = private constant [5 x i8] c"func\00" -@field_names.349 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.345, i64 4 }, { ptr, i64 } { ptr @fld.str.346, i64 4 }, { ptr, i64 } { ptr @fld.str.347, i64 3 }, { ptr, i64 } { ptr @fld.str.348, i64 4 }] -@str.350 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.351 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.355 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.361 = private constant [12 x i8] c"alloc_count\00" -@field_names.362 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 11 }] -@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.364 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.367 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.368 = private constant [5 x i8] c"next\00" -@fld.str.369 = private constant [4 x i8] c"cap\00" -@field_names.370 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 4 }, { ptr, i64 } { ptr @fld.str.369, i64 3 }] -@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.372 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.374 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.375 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.376 = private constant [4 x i8] c"ctx\00" -@fld.str.377 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.378 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.379 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.376, i64 3 }, { ptr, i64 } { ptr @fld.str.377, i64 11 }, { ptr, i64 } { ptr @fld.str.378, i64 13 }] -@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.381 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.385 = private constant [6 x i8] c"first\00" -@fld.str.386 = private constant [10 x i8] c"end_index\00" -@fld.str.387 = private constant [7 x i8] c"parent\00" -@field_names.388 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 5 }, { ptr, i64 } { ptr @fld.str.386, i64 9 }, { ptr, i64 } { ptr @fld.str.387, i64 6 }] -@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.390 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.394 = private constant [4 x i8] c"buf\00" -@fld.str.395 = private constant [4 x i8] c"len\00" -@fld.str.396 = private constant [4 x i8] c"pos\00" -@field_names.397 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 3 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }, { ptr, i64 } { ptr @fld.str.396, i64 3 }] -@str.398 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.399 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.400 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.401 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.402 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.403 = private constant [7 x i8] c"parent\00" -@fld.str.404 = private constant [12 x i8] c"alloc_count\00" -@fld.str.405 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.406 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.407 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.403, i64 6 }, { ptr, i64 } { ptr @fld.str.404, i64 11 }, { ptr, i64 } { ptr @fld.str.405, i64 13 }, { ptr, i64 } { ptr @fld.str.406, i64 17 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [10 x i8] c"allocator\00" -@fld.str.414 = private constant [5 x i8] c"data\00" -@field_names.415 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 9 }, { ptr, i64 } { ptr @fld.str.414, i64 4 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [3 x i8] c"fd\00" -@field_names.422 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 2 }] -@str.423 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.424 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.425 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.426 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.427 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.428 = private constant [5 x i8] c"file\00" -@fld.str.429 = private constant [5 x i8] c"line\00" -@fld.str.430 = private constant [4 x i8] c"col\00" -@fld.str.431 = private constant [5 x i8] c"func\00" -@fld.str.432 = private constant [10 x i8] c"line_text\00" -@field_names.433 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.428, i64 4 }, { ptr, i64 } { ptr @fld.str.429, i64 4 }, { ptr, i64 } { ptr @fld.str.430, i64 3 }, { ptr, i64 } { ptr @fld.str.431, i64 4 }, { ptr, i64 } { ptr @fld.str.432, i64 9 }] -@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.435 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.436 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.438 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.439 = private constant [10 x i8] c"exit_code\00" -@fld.str.440 = private constant [7 x i8] c"stdout\00" -@field_names.441 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 9 }, { ptr, i64 } { ptr @fld.str.440, i64 6 }] -@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.443 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.447 = private constant [8 x i8] c"sin_len\00" -@fld.str.448 = private constant [11 x i8] c"sin_family\00" -@fld.str.449 = private constant [9 x i8] c"sin_port\00" -@fld.str.450 = private constant [9 x i8] c"sin_addr\00" -@fld.str.451 = private constant [9 x i8] c"sin_zero\00" -@field_names.452 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 7 }, { ptr, i64 } { ptr @fld.str.448, i64 10 }, { ptr, i64 } { ptr @fld.str.449, i64 8 }, { ptr, i64 } { ptr @fld.str.450, i64 8 }, { ptr, i64 } { ptr @fld.str.451, i64 8 }] -@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.454 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.458 = private constant [6 x i8] c"items\00" -@fld.str.459 = private constant [4 x i8] c"len\00" -@fld.str.460 = private constant [4 x i8] c"cap\00" -@field_names.461 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 5 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }] -@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.463 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.467 = private constant [6 x i8] c"items\00" -@fld.str.468 = private constant [4 x i8] c"len\00" -@fld.str.469 = private constant [4 x i8] c"cap\00" -@field_names.470 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 5 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }] -@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.472 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.476 = private constant [4 x i8] c"key\00" -@fld.str.477 = private constant [4 x i8] c"val\00" -@field_names.478 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [4 x i8] c"dst\00" -@fld.str.485 = private constant [4 x i8] c"pos\00" -@fld.str.486 = private constant [5 x i8] c"file\00" -@field_names.487 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 4 }] -@str.488 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.489 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.490 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.492 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.493 = private constant [4 x i8] c"src\00" -@fld.str.494 = private constant [4 x i8] c"pos\00" -@fld.str.495 = private constant [6 x i8] c"alloc\00" -@field_names.496 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 3 }, { ptr, i64 } { ptr @fld.str.495, i64 5 }] -@str.497 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.498 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.501 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.502 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.504 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.505 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.507 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.508 = private constant [5 x i8] c"name\00" -@fld.str.509 = private constant [12 x i8] c"takes_value\00" -@fld.str.510 = private constant [9 x i8] c"required\00" -@field_names.511 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.508, i64 4 }, { ptr, i64 } { ptr @fld.str.509, i64 11 }, { ptr, i64 } { ptr @fld.str.510, i64 8 }] -@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.513 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.514 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.515 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.516 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.517 = private constant [6 x i8] c"group\00" -@fld.str.518 = private constant [8 x i8] c"command\00" -@fld.str.519 = private constant [6 x i8] c"flags\00" -@field_names.520 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.517, i64 5 }, { ptr, i64 } { ptr @fld.str.518, i64 7 }, { ptr, i64 } { ptr @fld.str.519, i64 5 }] -@str.521 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.522 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.523 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.525 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.526 = private constant [4 x i8] c"set\00" -@fld.str.527 = private constant [6 x i8] c"value\00" -@field_names.528 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.526, i64 3 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] -@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.530 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.534 = private constant [6 x i8] c"index\00" -@fld.str.535 = private constant [6 x i8] c"token\00" -@field_names.536 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 5 }, { ptr, i64 } { ptr @fld.str.535, i64 5 }] -@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.538 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.542 = private constant [6 x i8] c"group\00" -@fld.str.543 = private constant [8 x i8] c"command\00" -@fld.str.544 = private constant [10 x i8] c"cmd_index\00" -@fld.str.545 = private constant [5 x i8] c"json\00" -@fld.str.546 = private constant [5 x i8] c"rest\00" -@fld.str.547 = private constant [5 x i8] c"spec\00" -@fld.str.548 = private constant [7 x i8] c"values\00" -@field_names.549 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 5 }, { ptr, i64 } { ptr @fld.str.543, i64 7 }, { ptr, i64 } { ptr @fld.str.544, i64 9 }, { ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 4 }, { ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 6 }] -@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.551 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.553 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.554 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.555 = private constant [2 x i8] c"h\00" -@fld.str.556 = private constant [4 x i8] c"buf\00" -@fld.str.557 = private constant [8 x i8] c"buf_len\00" -@fld.str.558 = private constant [10 x i8] c"total_len\00" -@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 1 }, { ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 9 }] -@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.562 = private constant [5 x i8] c"read\00" -@fld.str.563 = private constant [6 x i8] c"write\00" -@fld.str.564 = private constant [7 x i8] c"append\00" -@fld.str.565 = private constant [11 x i8] c"read_write\00" -@field_names.566 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 4 }, { ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 6 }, { ptr, i64 } { ptr @fld.str.565, i64 10 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [4 x i8] c"set\00" -@fld.str.571 = private constant [8 x i8] c"current\00" -@fld.str.572 = private constant [4 x i8] c"end\00" -@field_names.573 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 7 }, { ptr, i64 } { ptr @fld.str.572, i64 3 }] -@str.574 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.575 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.577 = private constant [6 x i8] c"null_\00" -@fld.str.578 = private constant [6 x i8] c"bool_\00" -@fld.str.579 = private constant [5 x i8] c"int_\00" -@fld.str.580 = private constant [4 x i8] c"str\00" -@fld.str.581 = private constant [6 x i8] c"array\00" -@fld.str.582 = private constant [7 x i8] c"object\00" -@field_names.583 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 3 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 6 }] -@str.584 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.585 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.586 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.587 = private constant [6 x i8] c"macos\00" -@fld.str.588 = private constant [6 x i8] c"linux\00" -@fld.str.589 = private constant [8 x i8] c"windows\00" -@fld.str.590 = private constant [5 x i8] c"wasm\00" -@fld.str.591 = private constant [4 x i8] c"ios\00" -@fld.str.592 = private constant [8 x i8] c"android\00" -@fld.str.593 = private constant [8 x i8] c"unknown\00" -@field_names.594 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 5 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 4 }, { ptr, i64 } { ptr @fld.str.591, i64 3 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }] -@str.595 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.598 = private constant [8 x i8] c"aarch64\00" -@fld.str.599 = private constant [7 x i8] c"x86_64\00" -@fld.str.600 = private constant [7 x i8] c"wasm32\00" -@fld.str.601 = private constant [7 x i8] c"wasm64\00" -@fld.str.602 = private constant [8 x i8] c"unknown\00" -@field_names.603 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.598, i64 7 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 6 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 7 }] -@str.604 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.633 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.634 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.635 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.638 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.640 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.643 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.649 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.652 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.655 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.658 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.661 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.664 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.673 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.679 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.682 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.685 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.688 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.691 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.694 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.700 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.703 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.706 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.709 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [6 x i8] c"**f32\00", align 1 -@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.736 = private unnamed_addr constant [10 x i8] c"*Lerpable\00", align 1 -@str.737 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.341 = private constant [5 x i8] c"lerp\00" +@field_names = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 3 }, { ptr, i64 } { ptr @fld.str.341, i64 4 }] +@str.342 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.343 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.347 = private constant [5 x i8] c"file\00" +@fld.str.348 = private constant [5 x i8] c"line\00" +@fld.str.349 = private constant [4 x i8] c"col\00" +@fld.str.350 = private constant [5 x i8] c"func\00" +@field_names.351 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.347, i64 4 }, { ptr, i64 } { ptr @fld.str.348, i64 4 }, { ptr, i64 } { ptr @fld.str.349, i64 3 }, { ptr, i64 } { ptr @fld.str.350, i64 4 }] +@str.352 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.353 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.354 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.356 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.357 = private constant [4 x i8] c"ctx\00" +@fld.str.358 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.359 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.360 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.357, i64 3 }, { ptr, i64 } { ptr @fld.str.358, i64 11 }, { ptr, i64 } { ptr @fld.str.359, i64 13 }] +@str.361 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.362 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.364 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.366 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.372 = private constant [12 x i8] c"alloc_count\00" +@field_names.373 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 11 }] +@str.374 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.375 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.378 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.379 = private constant [5 x i8] c"next\00" +@fld.str.380 = private constant [4 x i8] c"cap\00" +@field_names.381 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.379, i64 4 }, { ptr, i64 } { ptr @fld.str.380, i64 3 }] +@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.383 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.387 = private constant [6 x i8] c"first\00" +@fld.str.388 = private constant [10 x i8] c"end_index\00" +@fld.str.389 = private constant [7 x i8] c"parent\00" +@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 5 }, { ptr, i64 } { ptr @fld.str.388, i64 9 }, { ptr, i64 } { ptr @fld.str.389, i64 6 }] +@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.392 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.396 = private constant [4 x i8] c"buf\00" +@fld.str.397 = private constant [4 x i8] c"len\00" +@fld.str.398 = private constant [4 x i8] c"pos\00" +@field_names.399 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 3 }, { ptr, i64 } { ptr @fld.str.397, i64 3 }, { ptr, i64 } { ptr @fld.str.398, i64 3 }] +@str.400 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.401 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.402 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.403 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.404 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.405 = private constant [7 x i8] c"parent\00" +@fld.str.406 = private constant [12 x i8] c"alloc_count\00" +@fld.str.407 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.408 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.409 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.405, i64 6 }, { ptr, i64 } { ptr @fld.str.406, i64 11 }, { ptr, i64 } { ptr @fld.str.407, i64 13 }, { ptr, i64 } { ptr @fld.str.408, i64 17 }] +@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.411 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.415 = private constant [10 x i8] c"allocator\00" +@fld.str.416 = private constant [5 x i8] c"data\00" +@field_names.417 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 9 }, { ptr, i64 } { ptr @fld.str.416, i64 4 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [3 x i8] c"fd\00" +@field_names.424 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 2 }] +@str.425 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.426 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.427 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.428 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.429 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.430 = private constant [5 x i8] c"file\00" +@fld.str.431 = private constant [5 x i8] c"line\00" +@fld.str.432 = private constant [4 x i8] c"col\00" +@fld.str.433 = private constant [5 x i8] c"func\00" +@fld.str.434 = private constant [10 x i8] c"line_text\00" +@field_names.435 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.430, i64 4 }, { ptr, i64 } { ptr @fld.str.431, i64 4 }, { ptr, i64 } { ptr @fld.str.432, i64 3 }, { ptr, i64 } { ptr @fld.str.433, i64 4 }, { ptr, i64 } { ptr @fld.str.434, i64 9 }] +@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.437 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.441 = private constant [10 x i8] c"exit_code\00" +@fld.str.442 = private constant [7 x i8] c"stdout\00" +@field_names.443 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 9 }, { ptr, i64 } { ptr @fld.str.442, i64 6 }] +@str.444 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.445 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.446 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.447 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.448 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.449 = private constant [8 x i8] c"sin_len\00" +@fld.str.450 = private constant [11 x i8] c"sin_family\00" +@fld.str.451 = private constant [9 x i8] c"sin_port\00" +@fld.str.452 = private constant [9 x i8] c"sin_addr\00" +@fld.str.453 = private constant [9 x i8] c"sin_zero\00" +@field_names.454 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.449, i64 7 }, { ptr, i64 } { ptr @fld.str.450, i64 10 }, { ptr, i64 } { ptr @fld.str.451, i64 8 }, { ptr, i64 } { ptr @fld.str.452, i64 8 }, { ptr, i64 } { ptr @fld.str.453, i64 8 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.460 = private constant [6 x i8] c"items\00" +@fld.str.461 = private constant [4 x i8] c"len\00" +@fld.str.462 = private constant [4 x i8] c"cap\00" +@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.469 = private constant [6 x i8] c"items\00" +@fld.str.470 = private constant [4 x i8] c"len\00" +@fld.str.471 = private constant [4 x i8] c"cap\00" +@field_names.472 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 5 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }] +@str.473 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.474 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.477 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.478 = private constant [4 x i8] c"key\00" +@fld.str.479 = private constant [4 x i8] c"val\00" +@field_names.480 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [4 x i8] c"dst\00" +@fld.str.487 = private constant [4 x i8] c"pos\00" +@fld.str.488 = private constant [5 x i8] c"file\00" +@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 4 }] +@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.491 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.495 = private constant [4 x i8] c"src\00" +@fld.str.496 = private constant [4 x i8] c"pos\00" +@fld.str.497 = private constant [6 x i8] c"alloc\00" +@field_names.498 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.495, i64 3 }, { ptr, i64 } { ptr @fld.str.496, i64 3 }, { ptr, i64 } { ptr @fld.str.497, i64 5 }] +@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.500 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.503 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.504 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.506 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.510 = private constant [5 x i8] c"name\00" +@fld.str.511 = private constant [12 x i8] c"takes_value\00" +@fld.str.512 = private constant [9 x i8] c"required\00" +@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 4 }, { ptr, i64 } { ptr @fld.str.511, i64 11 }, { ptr, i64 } { ptr @fld.str.512, i64 8 }] +@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.515 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.519 = private constant [6 x i8] c"group\00" +@fld.str.520 = private constant [8 x i8] c"command\00" +@fld.str.521 = private constant [6 x i8] c"flags\00" +@field_names.522 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 5 }, { ptr, i64 } { ptr @fld.str.520, i64 7 }, { ptr, i64 } { ptr @fld.str.521, i64 5 }] +@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.524 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.525 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.527 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.528 = private constant [4 x i8] c"set\00" +@fld.str.529 = private constant [6 x i8] c"value\00" +@field_names.530 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.528, i64 3 }, { ptr, i64 } { ptr @fld.str.529, i64 5 }] +@str.531 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.532 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.535 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.536 = private constant [6 x i8] c"index\00" +@fld.str.537 = private constant [6 x i8] c"token\00" +@field_names.538 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.536, i64 5 }, { ptr, i64 } { ptr @fld.str.537, i64 5 }] +@str.539 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.540 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.542 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.543 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.544 = private constant [6 x i8] c"group\00" +@fld.str.545 = private constant [8 x i8] c"command\00" +@fld.str.546 = private constant [10 x i8] c"cmd_index\00" +@fld.str.547 = private constant [5 x i8] c"json\00" +@fld.str.548 = private constant [5 x i8] c"rest\00" +@fld.str.549 = private constant [5 x i8] c"spec\00" +@fld.str.550 = private constant [7 x i8] c"values\00" +@field_names.551 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.544, i64 5 }, { ptr, i64 } { ptr @fld.str.545, i64 7 }, { ptr, i64 } { ptr @fld.str.546, i64 9 }, { ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 4 }, { ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 6 }] +@str.552 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.553 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.555 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.556 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.557 = private constant [2 x i8] c"h\00" +@fld.str.558 = private constant [4 x i8] c"buf\00" +@fld.str.559 = private constant [8 x i8] c"buf_len\00" +@fld.str.560 = private constant [10 x i8] c"total_len\00" +@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 1 }, { ptr, i64 } { ptr @fld.str.558, i64 3 }, { ptr, i64 } { ptr @fld.str.559, i64 7 }, { ptr, i64 } { ptr @fld.str.560, i64 9 }] +@str.562 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.564 = private constant [5 x i8] c"read\00" +@fld.str.565 = private constant [6 x i8] c"write\00" +@fld.str.566 = private constant [7 x i8] c"append\00" +@fld.str.567 = private constant [11 x i8] c"read_write\00" +@field_names.568 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 4 }, { ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 6 }, { ptr, i64 } { ptr @fld.str.567, i64 10 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [4 x i8] c"set\00" +@fld.str.573 = private constant [8 x i8] c"current\00" +@fld.str.574 = private constant [4 x i8] c"end\00" +@field_names.575 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 3 }, { ptr, i64 } { ptr @fld.str.573, i64 7 }, { ptr, i64 } { ptr @fld.str.574, i64 3 }] +@str.576 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.577 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.579 = private constant [6 x i8] c"null_\00" +@fld.str.580 = private constant [6 x i8] c"bool_\00" +@fld.str.581 = private constant [5 x i8] c"int_\00" +@fld.str.582 = private constant [4 x i8] c"str\00" +@fld.str.583 = private constant [6 x i8] c"array\00" +@fld.str.584 = private constant [7 x i8] c"object\00" +@field_names.585 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 4 }, { ptr, i64 } { ptr @fld.str.582, i64 3 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 6 }] +@str.586 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.587 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.588 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.589 = private constant [6 x i8] c"macos\00" +@fld.str.590 = private constant [6 x i8] c"linux\00" +@fld.str.591 = private constant [8 x i8] c"windows\00" +@fld.str.592 = private constant [5 x i8] c"wasm\00" +@fld.str.593 = private constant [4 x i8] c"ios\00" +@fld.str.594 = private constant [8 x i8] c"android\00" +@fld.str.595 = private constant [8 x i8] c"unknown\00" +@field_names.596 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 5 }, { ptr, i64 } { ptr @fld.str.590, i64 5 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 3 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] +@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.600 = private constant [8 x i8] c"aarch64\00" +@fld.str.601 = private constant [7 x i8] c"x86_64\00" +@fld.str.602 = private constant [7 x i8] c"wasm32\00" +@fld.str.603 = private constant [7 x i8] c"wasm64\00" +@fld.str.604 = private constant [8 x i8] c"unknown\00" +@field_names.605 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.600, i64 7 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 6 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 7 }] +@str.606 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.634 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.635 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.636 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.637 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.640 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.642 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.645 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.651 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.654 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.657 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.660 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.663 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.666 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.675 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.681 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.684 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.687 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.690 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.693 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.696 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.702 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.705 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.708 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.711 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.735 = private unnamed_addr constant [6 x i8] c"**f32\00", align 1 +@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [10 x i8] c"*Lerpable\00", align 1 +@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.742 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind define internal float @f32.lerp(ptr %0, float %1, float %2, float %3) #0 { @@ -703,6 +703,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -922,7 +925,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1049,7 +1052,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1383,7 +1386,7 @@ entry: br i1 %icmp, label %if.then.377, label %if.merge.378 if.then.377: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.378: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1533,7 +1536,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1560,9 +1563,9 @@ entry: i64 19, label %match.arm.43 i64 20, label %match.arm.43 i64 21, label %match.arm.43 - i64 23, label %match.arm.43 - i64 25, label %match.arm.43 - i64 27, label %match.arm.43 + i64 22, label %match.arm.43 + i64 24, label %match.arm.43 + i64 26, label %match.arm.43 i64 28, label %match.arm.43 i64 31, label %match.arm.43 i64 33, label %match.arm.43 @@ -1603,9 +1606,9 @@ entry: i64 86, label %match.arm.48 i64 98, label %match.arm.48 i64 18, label %match.arm.49 - i64 22, label %match.arm.49 - i64 24, label %match.arm.49 - i64 26, label %match.arm.49 + i64 23, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 30, label %match.arm.49 i64 32, label %match.arm.49 @@ -1647,7 +1650,7 @@ match.merge.37: ; preds = %dispatch.merge.486, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1692,9 +1695,9 @@ match.arm.43: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 i64 21, label %dispatch.case.98 - i64 23, label %dispatch.case.99 - i64 25, label %dispatch.case.100 - i64 27, label %dispatch.case.101 + i64 22, label %dispatch.case.99 + i64 24, label %dispatch.case.100 + i64 26, label %dispatch.case.101 i64 28, label %dispatch.case.102 i64 31, label %dispatch.case.103 i64 33, label %dispatch.case.104 @@ -1775,9 +1778,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.340 [ i64 18, label %dispatch.case.341 - i64 22, label %dispatch.case.342 - i64 24, label %dispatch.case.343 - i64 26, label %dispatch.case.344 + i64 23, label %dispatch.case.342 + i64 25, label %dispatch.case.343 + i64 27, label %dispatch.case.344 i64 29, label %dispatch.case.345 i64 30, label %dispatch.case.346 i64 32, label %dispatch.case.347 @@ -1877,7 +1880,7 @@ dispatch.merge.94: ; preds = %dispatch.case.121, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1899,32 +1902,32 @@ dispatch.case.97: ; preds = %match.arm.43 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { ptr, ptr, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) + %ua.load74 = load {}, ptr %ua.ptr73, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) + %ua.load78 = load { i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.101: ; preds = %match.arm.43 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, ptr, ptr }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load82) + %ua.load82 = load { ptr, i64 }, ptr %ua.ptr81, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load82) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2094,7 +2097,7 @@ dispatch.merge.252: ; preds = %dispatch.case.258, br label %match.merge.37 dispatch.default.253: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.252 dispatch.case.254: ; preds = %match.arm.44 @@ -2135,7 +2138,7 @@ dispatch.merge.269: ; preds = %dispatch.case.276, br label %match.merge.37 dispatch.default.270: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.269 dispatch.case.271: ; preds = %match.arm.47 @@ -2192,7 +2195,7 @@ dispatch.merge.307: ; preds = %dispatch.case.313, br label %match.merge.37 dispatch.default.308: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2241,7 +2244,7 @@ dispatch.merge.339: ; preds = %dispatch.case.373, br label %match.merge.37 dispatch.default.340: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2481,7 +2484,7 @@ dispatch.merge.486: ; preds = %dispatch.case.491, br label %match.merge.37 dispatch.default.487: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.486 dispatch.case.488: ; preds = %match.arm.50 @@ -2523,7 +2526,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.314, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2619,7 +2622,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2627,7 +2630,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2637,13 +2640,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2651,7 +2654,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2665,7 +2668,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2673,7 +2676,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2684,7 +2687,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2741,7 +2744,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2749,7 +2752,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2760,7 +2763,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2780,7 +2783,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2788,7 +2791,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, 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 @@ -2799,7 +2802,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2809,64 +2812,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3042,163 +3048,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3396,64 +3405,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3483,97 +3492,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3612,7 +3621,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal ptr @__thunk_CAllocator_Allocator_alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { @@ -3632,7 +3641,7 @@ entry: define internal void @print__ct_s648b4567d2e0e089__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.329, i64 22 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.331, i64 22 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3649,7 +3658,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 19) @@ -3678,7 +3687,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.331, i64 22 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.333, i64 22 }) ret { ptr, i64 } %call } @@ -3697,7 +3706,7 @@ entry: define internal void @print__ct_s865ed00fd204d3cc__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.332, i64 23 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.334, i64 23 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3714,7 +3723,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 20) @@ -3743,7 +3752,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.334, i64 23 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.336, i64 23 }) ret { ptr, i64 } %call } @@ -3752,7 +3761,7 @@ define internal { ptr, i64 } @struct_to_string__Lerpable(ptr %0, { ptr, ptr } %1 entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.335, i64 8 }, { ptr, i64 } { ptr @str.336, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.337, i64 8 }, { ptr, i64 } { ptr @str.338, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3771,12 +3780,12 @@ while.body.123: ; preds = %while.hdr.122 while.exit.124: ; preds = %while.hdr.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 1 }) ret { ptr, i64 } %callN if.then.125: ; preds = %while.body.123 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.126 @@ -3788,7 +3797,7 @@ if.merge.126: ; preds = %if.then.125, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -3831,7 +3840,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.341, i64 15 }, { ptr, i64 } { ptr @str.342, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 15 }, { ptr, i64 } { ptr @str.344, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3850,24 +3859,24 @@ while.body.128: ; preds = %while.hdr.127 while.exit.129: ; preds = %while.hdr.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) ret { ptr, i64 } %callN if.then.130: ; preds = %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.131 if.merge.131: ; preds = %if.then.130, %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.349, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.351, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3920,20 +3929,20 @@ fv.case24: ; preds = %if.merge.131 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 10 }, { ptr, i64 } { ptr @str.352, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.353, i64 9 }, { ptr, i64 } { ptr @str.354, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.132 -while.hdr.132: ; preds = %if.merge.136, %entry +while.hdr.132: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.133, label %while.exit.134 while.body.133: ; preds = %while.hdr.132 @@ -3943,224 +3952,24 @@ while.body.133: ; preds = %while.hdr.132 while.exit.134: ; preds = %while.hdr.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 1 }) ret { ptr, i64 } %callN if.then.135: ; preds = %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.136 if.merge.136: ; preds = %if.then.135, %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.355, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.360, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.132 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 3 }, { ptr, i64 } { ptr @str.358, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.137 - -while.hdr.137: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.138, label %while.exit.139 - -while.body.138: ; preds = %while.hdr.137 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.140, label %if.merge.141 - -while.exit.139: ; preds = %while.hdr.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) - ret { ptr, i64 } %callN - -if.then.140: ; preds = %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.141 - -if.merge.141: ; preds = %if.then.140, %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.362, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 - -fv.default: ; preds = %if.merge.141 - br label %fv.merge - -fv.case: ; preds = %if.merge.141 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.364, i64 10 }, { ptr, i64 } { ptr @str.365, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 - -while.hdr.142: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.143, label %while.exit.144 - -while.body.143: ; preds = %while.hdr.142 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 - -while.exit.144: ; preds = %while.hdr.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 1 }) - ret { ptr, i64 } %callN - -if.then.145: ; preds = %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 - -if.merge.146: ; preds = %if.then.145, %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.370, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 - -fv.default: ; preds = %if.merge.146 - br label %fv.merge - -fv.case: ; preds = %if.merge.146 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.146 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.372, i64 9 }, { ptr, i64 } { ptr @str.373, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 - -while.hdr.147: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.148, label %while.exit.149 - -while.body.148: ; preds = %while.hdr.147 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 - -while.exit.149: ; preds = %while.hdr.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 1 }) - ret { ptr, i64 } %callN - -if.then.150: ; preds = %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 - -if.merge.151: ; preds = %if.then.150, %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.379, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, 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 @@ -4179,27 +3988,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.132 + +fv.default: ; preds = %if.merge.136 + br label %fv.merge + +fv.case: ; preds = %if.merge.136 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.136 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.136 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.362, i64 10 }, { ptr, i64 } { ptr @str.363, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.137 + +while.hdr.137: ; preds = %if.merge.141, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.138, label %while.exit.139 + +while.body.138: ; preds = %while.hdr.137 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.140, label %if.merge.141 + +while.exit.139: ; preds = %while.hdr.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 1 }) + ret { ptr, i64 } %callN + +if.then.140: ; preds = %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.141 + +if.merge.141: ; preds = %if.then.140, %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.366, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 3 }, { ptr, i64 } { ptr @str.369, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.142 + +while.hdr.142: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.143, label %while.exit.144 + +while.body.143: ; preds = %while.hdr.142 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.145, label %if.merge.146 + +while.exit.144: ; preds = %while.hdr.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.145: ; preds = %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.146 + +if.merge.146: ; preds = %if.then.145, %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.373, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.142 + +fv.default: ; preds = %if.merge.146 + br label %fv.merge + +fv.case: ; preds = %if.merge.146 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.375, i64 10 }, { ptr, i64 } { ptr @str.376, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.147 + +while.hdr.147: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.148, label %while.exit.149 + +while.body.148: ; preds = %while.hdr.147 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.150, label %if.merge.151 + +while.exit.149: ; preds = %while.hdr.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 1 }) + ret { ptr, i64 } %callN + +if.then.150: ; preds = %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.151 + +if.merge.151: ; preds = %if.then.150, %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.381, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.147 fv.default: ; preds = %if.merge.151 br label %fv.merge fv.case: ; preds = %if.merge.151 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 27, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.151 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.151 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4209,7 +4218,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 5 }, { ptr, i64 } { ptr @str.382, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 5 }, { ptr, i64 } { ptr @str.384, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4228,24 +4237,24 @@ while.body.153: ; preds = %while.hdr.152 while.exit.154: ; preds = %while.hdr.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) ret { ptr, i64 } %callN if.then.155: ; preds = %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.156 if.merge.156: ; preds = %if.then.155, %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.388, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.390, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, 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 @@ -4272,7 +4281,7 @@ fv.default: ; preds = %if.merge.156 fv.case: ; preds = %if.merge.156 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 27, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.156 @@ -4284,7 +4293,7 @@ fv.case20: ; preds = %if.merge.156 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 27, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 21, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4293,7 +4302,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 8 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 8 }, { ptr, i64 } { ptr @str.393, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4312,24 +4321,24 @@ while.body.158: ; preds = %while.hdr.157 while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) ret { ptr, i64 } %callN if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.161 if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.397, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.399, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, 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 @@ -4376,7 +4385,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 17 }, { ptr, i64 } { ptr @str.400, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.401, i64 17 }, { ptr, i64 } { ptr @str.402, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4395,24 +4404,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4441,7 +4450,7 @@ fv.case: ; preds = %if.merge.166 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 27, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 21, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 @@ -4466,7 +4475,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 7 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 7 }, { ptr, i64 } { ptr @str.412, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4485,24 +4494,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, 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 @@ -4529,7 +4538,7 @@ fv.case: ; preds = %if.merge.171 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 27, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 21, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 @@ -4544,7 +4553,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 4 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 4 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4563,24 +4572,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %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.422, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.424, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4617,7 +4626,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.424, i64 10 }, { ptr, i64 } { ptr @str.425, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 10 }, { ptr, i64 } { ptr @str.427, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4636,24 +4645,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.433, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4719,7 +4728,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 13 }, { ptr, i64 } { ptr @str.436, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 13 }, { ptr, i64 } { ptr @str.438, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4738,24 +4747,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %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.441, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.443, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4797,7 +4806,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 8 }, { ptr, i64 } { ptr @str.444, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 8 }, { ptr, i64 } { ptr @str.446, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4816,24 +4825,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4894,7 +4903,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 5 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 5 }, { ptr, i64 } { ptr @str.457, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4913,24 +4922,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %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.461, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.463, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, 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 @@ -4976,7 +4985,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 6 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4995,24 +5004,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %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.470, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.472, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, 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 @@ -5060,7 +5069,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 6 }, { ptr, i64 } { ptr @str.473, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.474, i64 6 }, { ptr, i64 } { ptr @str.475, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5079,24 +5088,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5140,7 +5149,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 4 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 4 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5159,24 +5168,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.487, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.489, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5226,7 +5235,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 6 }, { ptr, i64 } { ptr @str.490, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 6 }, { ptr, i64 } { ptr @str.492, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5245,24 +5254,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.496, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.498, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5302,7 +5311,7 @@ fv.case20: ; preds = %if.merge.216 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 27, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 21, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5311,7 +5320,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.498, i64 12 }, { ptr, i64 } { ptr @str.499, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 12 }, { ptr, i64 } { ptr @str.501, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5330,24 +5339,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.502, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.504, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5367,7 +5376,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 8 }, { ptr, i64 } { ptr @str.505, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 8 }, { ptr, i64 } { ptr @str.507, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5386,24 +5395,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.511, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.513, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5455,7 +5464,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 7 }, { ptr, i64 } { ptr @str.514, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 7 }, { ptr, i64 } { ptr @str.516, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5474,24 +5483,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.520, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.522, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5543,7 +5552,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.522, i64 9 }, { ptr, i64 } { ptr @str.523, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 9 }, { ptr, i64 } { ptr @str.525, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5562,24 +5571,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.528, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.530, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5622,7 +5631,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 4 }, { ptr, i64 } { ptr @str.531, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.532, i64 4 }, { ptr, i64 } { ptr @str.533, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5641,24 +5650,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %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.536, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.538, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5704,7 +5713,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 6 }, { ptr, i64 } { ptr @str.539, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5723,24 +5732,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.549, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.551, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5822,7 +5831,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, i64 6 }, { ptr, i64 } { ptr @str.552, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 6 }, { ptr, i64 } { ptr @str.554, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5841,24 +5850,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5917,9 +5926,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, 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 @@ -5938,8 +5947,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -5958,9 +5967,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, 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 @@ -5979,8 +5988,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6010,9 +6019,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.585, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6029,8 +6038,8 @@ entry: if.then.263: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 @@ -6108,9 +6117,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, 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 @@ -6129,8 +6138,8 @@ entry: if.then.265: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.595, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -6149,9 +6158,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.605, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, 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 @@ -6170,8 +6179,8 @@ entry: if.then.267: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -6188,7 +6197,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.277 @@ -6205,12 +6214,12 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) ret { ptr, i64 } %call if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 @@ -6239,7 +6248,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.282 @@ -6256,12 +6265,12 @@ while.body.283: ; preds = %while.hdr.282 while.exit.284: ; preds = %while.hdr.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) ret { ptr, i64 } %call if.then.285: ; preds = %while.body.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6291,7 +6300,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.287 @@ -6308,12 +6317,12 @@ while.body.288: ; preds = %while.hdr.287 while.exit.289: ; preds = %while.hdr.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) ret { ptr, i64 } %call if.then.290: ; preds = %while.body.288 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -6341,7 +6350,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.292 @@ -6358,12 +6367,12 @@ while.body.293: ; preds = %while.hdr.292 while.exit.294: ; preds = %while.hdr.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) ret { ptr, i64 } %call if.then.295: ; preds = %while.body.293 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6392,7 +6401,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.297 @@ -6409,12 +6418,12 @@ while.body.298: ; preds = %while.hdr.297 while.exit.299: ; preds = %while.hdr.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) ret { ptr, i64 } %call if.then.300: ; preds = %while.body.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.301 @@ -6443,7 +6452,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.302 @@ -6460,12 +6469,12 @@ while.body.303: ; preds = %while.hdr.302 while.exit.304: ; preds = %while.hdr.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) ret { ptr, i64 } %call if.then.305: ; preds = %while.body.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.306 @@ -6495,7 +6504,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6514,12 +6523,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6548,7 +6557,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.319 @@ -6567,12 +6576,12 @@ while.body.320: ; preds = %while.hdr.319 while.exit.321: ; preds = %while.hdr.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) ret { ptr, i64 } %call if.then.322: ; preds = %while.body.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.323 @@ -6601,7 +6610,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.632, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.324 @@ -6620,12 +6629,12 @@ while.body.325: ; preds = %while.hdr.324 while.exit.326: ; preds = %while.hdr.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) ret { ptr, i64 } %call if.then.327: ; preds = %while.body.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.328 @@ -6655,7 +6664,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.633, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.635, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.329 @@ -6674,12 +6683,12 @@ while.body.330: ; preds = %while.hdr.329 while.exit.331: ; preds = %while.hdr.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 1 }) ret { ptr, i64 } %call if.then.332: ; preds = %while.body.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.333 @@ -6709,7 +6718,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.636, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.638, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.334 @@ -6728,12 +6737,12 @@ while.body.335: ; preds = %while.hdr.334 while.exit.336: ; preds = %while.hdr.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) ret { ptr, i64 } %call if.then.337: ; preds = %while.body.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.338 @@ -6775,12 +6784,12 @@ if.then.374: ; preds = %entry if.else.375: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 5 }, { ptr, i64 } %callN) br label %if.merge.376 if.merge.376: ; preds = %if.else.375, %if.then.374 - %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.374 ], [ %callN, %if.else.375 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.374 ], [ %callN, %if.else.375 ] ret { ptr, i64 } %bp } @@ -6803,12 +6812,12 @@ if.then.390: ; preds = %entry if.else.391: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 11 }, { ptr, i64 } %callN) br label %if.merge.392 if.merge.392: ; preds = %if.else.391, %if.then.390 - %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -6831,12 +6840,12 @@ if.then.393: ; preds = %entry if.else.394: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 4 }, { ptr, i64 } %callN) br label %if.merge.395 if.merge.395: ; preds = %if.else.394, %if.then.393 - %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] ret { ptr, i64 } %bp } @@ -6859,12 +6868,12 @@ if.then.396: ; preds = %entry if.else.397: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 11 }, { ptr, i64 } %callN) br label %if.merge.398 if.merge.398: ; preds = %if.else.397, %if.then.396 - %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6887,12 +6896,12 @@ if.then.399: ; preds = %entry if.else.400: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 6 }, { ptr, i64 } %callN) br label %if.merge.401 if.merge.401: ; preds = %if.else.400, %if.then.399 - %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] ret { ptr, i64 } %bp } @@ -6914,12 +6923,12 @@ if.then.402: ; preds = %entry if.else.403: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) br label %if.merge.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6942,12 +6951,12 @@ if.then.405: ; preds = %entry if.else.406: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 9 }, { ptr, i64 } %callN) br label %if.merge.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -6970,12 +6979,12 @@ if.then.408: ; preds = %entry if.else.409: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 18 }, { ptr, i64 } %callN) br label %if.merge.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -6998,12 +7007,12 @@ if.then.411: ; preds = %entry if.else.412: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 5 }, { ptr, i64 } %callN) br label %if.merge.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7026,12 +7035,12 @@ if.then.414: ; preds = %entry if.else.415: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %callN) br label %if.merge.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7054,12 +7063,12 @@ if.then.417: ; preds = %entry if.else.418: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 4 }, { ptr, i64 } %callN) br label %if.merge.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7082,12 +7091,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 9 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7110,12 +7119,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 4 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7137,12 +7146,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 8 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7165,12 +7174,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 6 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7192,12 +7201,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 9 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7220,12 +7229,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 7 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7248,12 +7257,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 5 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7276,12 +7285,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 7 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7304,12 +7313,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 4 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7332,12 +7341,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 7 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7360,12 +7369,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 5 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7388,12 +7397,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 7 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7416,12 +7425,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 12 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7444,12 +7453,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 6 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7472,12 +7481,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 4 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7500,12 +7509,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7528,12 +7537,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 4 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7556,12 +7565,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 7 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7584,12 +7593,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7612,12 +7621,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7640,12 +7649,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 5 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7668,12 +7677,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 9 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -7689,7 +7698,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.738, i64 4 } + ret { ptr, i64 } { ptr @str.740, i64 4 } if.merge.493: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7713,7 +7722,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.739, i64 4 } + ret { ptr, i64 } { ptr @str.741, i64 4 } if.merge.495: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7737,7 +7746,7 @@ entry: br i1 %lnot, label %if.then.496, label %if.merge.497 if.then.496: ; preds = %entry - ret { ptr, i64 } { ptr @str.740, i64 4 } + ret { ptr, i64 } { ptr @str.742, i64 4 } if.merge.497: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7761,7 +7770,7 @@ entry: br i1 %lnot, label %if.then.498, label %if.merge.499 if.then.498: ; preds = %entry - ret { ptr, i64 } { ptr @str.741, i64 4 } + ret { ptr, i64 } { ptr @str.743, i64 4 } if.merge.499: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0413-protocols-parameterized-protocol-value.ir b/examples/expected/0413-protocols-parameterized-protocol-value.ir index 5429bfb..fc66583 100644 --- a/examples/expected/0413-protocols-parameterized-protocol-value.ir +++ b/examples/expected/0413-protocols-parameterized-protocol-value.ir @@ -3,696 +3,696 @@ @__VL__s64__IntCell__vtable = internal constant { ptr } { ptr @__thunk_IntCell_VL__s64_get } @__VL__string__StrCell__vtable = internal constant { ptr } { ptr @__thunk_StrCell_VL__string_get } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [179 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [8 x i8] c"IntCell\00" -@tn.str.237 = private constant [8 x i8] c"StrCell\00" -@tn.str.238 = private constant [9 x i8] c"*IntCell\00" -@tn.str.239 = private constant [9 x i8] c"*StrCell\00" -@tn.str.240 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.241 = private constant [7 x i8] c"**void\00" -@tn.str.242 = private constant [8 x i8] c"VL__s64\00" -@tn.str.243 = private constant [18 x i8] c"__VL__s64__Vtable\00" -@tn.str.244 = private constant [9 x i8] c"*VL__s64\00" -@tn.str.245 = private constant [10 x i8] c"**IntCell\00" -@tn.str.246 = private constant [19 x i8] c"*__VL__s64__Vtable\00" -@tn.str.247 = private constant [8 x i8] c"*string\00" -@tn.str.248 = private constant [6 x i8] c"[]Any\00" -@tn.str.249 = private constant [5 x i8] c"*Any\00" -@tn.str.250 = private constant [7 x i8] c"[1]Any\00" -@tn.str.251 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.252 = private constant [7 x i8] c"*[]Any\00" -@tn.str.253 = private constant [6 x i8] c"*bool\00" -@tn.str.254 = private constant [11 x i8] c"VL__string\00" -@tn.str.255 = private constant [21 x i8] c"__VL__string__Vtable\00" -@tn.str.256 = private constant [12 x i8] c"*VL__string\00" -@tn.str.257 = private constant [10 x i8] c"**StrCell\00" -@tn.str.258 = private constant [22 x i8] c"*__VL__string__Vtable\00" -@tn.str.259 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.260 = private constant [5 x i8] c"*f64\00" -@tn.str.261 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.262 = private constant [11 x i8] c"*Allocator\00" -@tn.str.263 = private constant [9 x i8] c"*Context\00" -@tn.str.264 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.265 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.266 = private constant [8 x i8] c"*Member\00" -@tn.str.267 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.268 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.269 = private constant [9 x i8] c"*Command\00" -@tn.str.270 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.271 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.272 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.273 = private constant [7 x i8] c"*Value\00" -@tn.str.274 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.275 = private constant [14 x i8] c"*Architecture\00" -@tn.str.276 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.277 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.278 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.279 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.280 = private constant [10 x i8] c"*[]string\00" -@tn.str.281 = private constant [6 x i8] c"*[]u8\00" -@tn.str.282 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.283 = private constant [11 x i8] c"*[]Command\00" -@tn.str.284 = private constant [6 x i8] c"**GPA\00" -@tn.str.285 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.286 = private constant [8 x i8] c"**Arena\00" -@tn.str.287 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.288 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.289 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.290 = private constant [7 x i8] c"**File\00" -@tn.str.291 = private constant [5 x i8] c"**u8\00" -@tn.str.292 = private constant [6 x i8] c"**s32\00" -@tn.str.293 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.294 = private constant [6 x i8] c"**u32\00" -@tn.str.295 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.296 = private constant [8 x i8] c"**Array\00" -@tn.str.297 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.298 = private constant [9 x i8] c"**Object\00" -@tn.str.299 = private constant [7 x i8] c"**Sink\00" -@tn.str.300 = private constant [9 x i8] c"**Parser\00" -@tn.str.301 = private constant [6 x i8] c"**s64\00" -@tn.str.302 = private constant [9 x i8] c"**Parsed\00" -@tn.str.303 = private constant [7 x i8] c"**Diag\00" -@tn.str.304 = private constant [9 x i8] c"**Sha256\00" -@tn.str.305 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.306 = private constant [8 x i8] c"***void\00" -@tn.str.307 = private constant [10 x i8] c"**VL__s64\00" -@tn.str.308 = private constant [11 x i8] c"***IntCell\00" -@tn.str.309 = private constant [20 x i8] c"**__VL__s64__Vtable\00" -@tn.str.310 = private constant [9 x i8] c"**string\00" -@tn.str.311 = private constant [6 x i8] c"**Any\00" -@tn.str.312 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.313 = private constant [8 x i8] c"**[]Any\00" -@tn.str.314 = private constant [7 x i8] c"**bool\00" -@tn.str.315 = private constant [13 x i8] c"**VL__string\00" -@tn.str.316 = private constant [11 x i8] c"***StrCell\00" -@tn.str.317 = private constant [23 x i8] c"**__VL__string__Vtable\00" -@tn.str.318 = private constant [7 x i8] c"*?File\00" -@tn.str.319 = private constant [9 x i8] c"*?string\00" -@tn.str.320 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.321 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [179 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 8 }, { ptr, i64 } { ptr @tn.str.239, i64 8 }, { ptr, i64 } { ptr @tn.str.240, i64 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 17 }, { ptr, i64 } { ptr @tn.str.244, i64 8 }, { ptr, i64 } { ptr @tn.str.245, i64 9 }, { ptr, i64 } { ptr @tn.str.246, i64 18 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 4 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 5 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 20 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 9 }, { ptr, i64 } { ptr @tn.str.258, i64 21 }, { ptr, i64 } { ptr @tn.str.259, i64 7 }, { ptr, i64 } { ptr @tn.str.260, i64 4 }, { ptr, i64 } { ptr @tn.str.261, i64 16 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 8 }, { ptr, i64 } { ptr @tn.str.264, i64 11 }, { ptr, i64 } { ptr @tn.str.265, i64 14 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 10 }, { ptr, i64 } { ptr @tn.str.271, i64 9 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 6 }, { ptr, i64 } { ptr @tn.str.274, i64 16 }, { ptr, i64 } { ptr @tn.str.275, i64 13 }, { ptr, i64 } { ptr @tn.str.276, i64 14 }, { ptr, i64 } { ptr @tn.str.277, i64 7 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 8 }, { ptr, i64 } { ptr @tn.str.280, i64 9 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 11 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 12 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 10 }, { ptr, i64 } { ptr @tn.str.289, i64 19 }, { ptr, i64 } { ptr @tn.str.290, i64 6 }, { ptr, i64 } { ptr @tn.str.291, i64 4 }, { ptr, i64 } { ptr @tn.str.292, i64 5 }, { ptr, i64 } { ptr @tn.str.293, i64 10 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 9 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 10 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 13 }, { ptr, i64 } { ptr @tn.str.306, i64 7 }, { ptr, i64 } { ptr @tn.str.307, i64 9 }, { ptr, i64 } { ptr @tn.str.308, i64 10 }, { ptr, i64 } { ptr @tn.str.309, i64 19 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }, { ptr, i64 } { ptr @tn.str.311, i64 5 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 7 }, { ptr, i64 } { ptr @tn.str.314, i64 6 }, { ptr, i64 } { ptr @tn.str.315, i64 12 }, { ptr, i64 } { ptr @tn.str.316, i64 10 }, { ptr, i64 } { ptr @tn.str.317, i64 22 }, { ptr, i64 } { ptr @tn.str.318, i64 6 }, { ptr, i64 } { ptr @tn.str.319, i64 8 }, { ptr, i64 } { ptr @tn.str.320, i64 15 }, { ptr, i64 } { ptr @tn.str.321, i64 8 }] -@str.322 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.323 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [8 x i8] c"IntCell\00" +@tn.str.239 = private constant [8 x i8] c"StrCell\00" +@tn.str.240 = private constant [9 x i8] c"*IntCell\00" +@tn.str.241 = private constant [9 x i8] c"*StrCell\00" +@tn.str.242 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.243 = private constant [7 x i8] c"**void\00" +@tn.str.244 = private constant [8 x i8] c"VL__s64\00" +@tn.str.245 = private constant [18 x i8] c"__VL__s64__Vtable\00" +@tn.str.246 = private constant [9 x i8] c"*VL__s64\00" +@tn.str.247 = private constant [10 x i8] c"**IntCell\00" +@tn.str.248 = private constant [19 x i8] c"*__VL__s64__Vtable\00" +@tn.str.249 = private constant [8 x i8] c"*string\00" +@tn.str.250 = private constant [6 x i8] c"[]Any\00" +@tn.str.251 = private constant [5 x i8] c"*Any\00" +@tn.str.252 = private constant [7 x i8] c"[1]Any\00" +@tn.str.253 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.254 = private constant [7 x i8] c"*[]Any\00" +@tn.str.255 = private constant [6 x i8] c"*bool\00" +@tn.str.256 = private constant [11 x i8] c"VL__string\00" +@tn.str.257 = private constant [21 x i8] c"__VL__string__Vtable\00" +@tn.str.258 = private constant [12 x i8] c"*VL__string\00" +@tn.str.259 = private constant [10 x i8] c"**StrCell\00" +@tn.str.260 = private constant [22 x i8] c"*__VL__string__Vtable\00" +@tn.str.261 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.262 = private constant [5 x i8] c"*f64\00" +@tn.str.263 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.264 = private constant [11 x i8] c"*Allocator\00" +@tn.str.265 = private constant [9 x i8] c"*Context\00" +@tn.str.266 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.267 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.268 = private constant [8 x i8] c"*Member\00" +@tn.str.269 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.270 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.271 = private constant [9 x i8] c"*Command\00" +@tn.str.272 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.273 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.274 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.275 = private constant [7 x i8] c"*Value\00" +@tn.str.276 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.277 = private constant [14 x i8] c"*Architecture\00" +@tn.str.278 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.279 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.280 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.281 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.282 = private constant [10 x i8] c"*[]string\00" +@tn.str.283 = private constant [6 x i8] c"*[]u8\00" +@tn.str.284 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.285 = private constant [11 x i8] c"*[]Command\00" +@tn.str.286 = private constant [6 x i8] c"**GPA\00" +@tn.str.287 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.288 = private constant [8 x i8] c"**Arena\00" +@tn.str.289 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.290 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.291 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.292 = private constant [7 x i8] c"**File\00" +@tn.str.293 = private constant [5 x i8] c"**u8\00" +@tn.str.294 = private constant [6 x i8] c"**s32\00" +@tn.str.295 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.296 = private constant [6 x i8] c"**u32\00" +@tn.str.297 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.298 = private constant [8 x i8] c"**Array\00" +@tn.str.299 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.300 = private constant [9 x i8] c"**Object\00" +@tn.str.301 = private constant [7 x i8] c"**Sink\00" +@tn.str.302 = private constant [9 x i8] c"**Parser\00" +@tn.str.303 = private constant [6 x i8] c"**s64\00" +@tn.str.304 = private constant [9 x i8] c"**Parsed\00" +@tn.str.305 = private constant [7 x i8] c"**Diag\00" +@tn.str.306 = private constant [9 x i8] c"**Sha256\00" +@tn.str.307 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.308 = private constant [8 x i8] c"***void\00" +@tn.str.309 = private constant [10 x i8] c"**VL__s64\00" +@tn.str.310 = private constant [11 x i8] c"***IntCell\00" +@tn.str.311 = private constant [20 x i8] c"**__VL__s64__Vtable\00" +@tn.str.312 = private constant [9 x i8] c"**string\00" +@tn.str.313 = private constant [6 x i8] c"**Any\00" +@tn.str.314 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.315 = private constant [8 x i8] c"**[]Any\00" +@tn.str.316 = private constant [7 x i8] c"**bool\00" +@tn.str.317 = private constant [13 x i8] c"**VL__string\00" +@tn.str.318 = private constant [11 x i8] c"***StrCell\00" +@tn.str.319 = private constant [23 x i8] c"**__VL__string__Vtable\00" +@tn.str.320 = private constant [7 x i8] c"*?File\00" +@tn.str.321 = private constant [9 x i8] c"*?string\00" +@tn.str.322 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.323 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [179 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 8 }, { ptr, i64 } { ptr @tn.str.241, i64 8 }, { ptr, i64 } { ptr @tn.str.242, i64 12 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 17 }, { ptr, i64 } { ptr @tn.str.246, i64 8 }, { ptr, i64 } { ptr @tn.str.247, i64 9 }, { ptr, i64 } { ptr @tn.str.248, i64 18 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 4 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 6 }, { ptr, i64 } { ptr @tn.str.255, i64 5 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 20 }, { ptr, i64 } { ptr @tn.str.258, i64 11 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 21 }, { ptr, i64 } { ptr @tn.str.261, i64 7 }, { ptr, i64 } { ptr @tn.str.262, i64 4 }, { ptr, i64 } { ptr @tn.str.263, i64 16 }, { ptr, i64 } { ptr @tn.str.264, i64 10 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 11 }, { ptr, i64 } { ptr @tn.str.267, i64 14 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 13 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 10 }, { ptr, i64 } { ptr @tn.str.273, i64 9 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 16 }, { ptr, i64 } { ptr @tn.str.277, i64 13 }, { ptr, i64 } { ptr @tn.str.278, i64 14 }, { ptr, i64 } { ptr @tn.str.279, i64 7 }, { ptr, i64 } { ptr @tn.str.280, i64 7 }, { ptr, i64 } { ptr @tn.str.281, i64 8 }, { ptr, i64 } { ptr @tn.str.282, i64 9 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 11 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 12 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 10 }, { ptr, i64 } { ptr @tn.str.291, i64 19 }, { ptr, i64 } { ptr @tn.str.292, i64 6 }, { ptr, i64 } { ptr @tn.str.293, i64 4 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 10 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 9 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 10 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 13 }, { ptr, i64 } { ptr @tn.str.308, i64 7 }, { ptr, i64 } { ptr @tn.str.309, i64 9 }, { ptr, i64 } { ptr @tn.str.310, i64 10 }, { ptr, i64 } { ptr @tn.str.311, i64 19 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 5 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { ptr, i64 } { ptr @tn.str.315, i64 7 }, { ptr, i64 } { ptr @tn.str.316, i64 6 }, { ptr, i64 } { ptr @tn.str.317, i64 12 }, { ptr, i64 } { ptr @tn.str.318, i64 10 }, { ptr, i64 } { ptr @tn.str.319, i64 22 }, { ptr, i64 } { ptr @tn.str.320, i64 6 }, { ptr, i64 } { ptr @tn.str.321, i64 8 }, { ptr, i64 } { ptr @tn.str.322, i64 15 }, { ptr, i64 } { ptr @tn.str.323, i64 8 }] @str.324 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.325 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.326 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.328 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.329 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.330 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.331 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.332 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.333 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.334 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.335 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.336 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.337 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.338 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.339 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.340 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.342 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.343 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 -@str.344 = private unnamed_addr constant [10 x i8] c"a.get={}\0A\00", align 1 -@str.345 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.328 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.331 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.332 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.333 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.334 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.335 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.336 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.337 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.338 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.339 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.341 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.342 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.343 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.344 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.345 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 @str.346 = private unnamed_addr constant [10 x i8] c"a.get={}\0A\00", align 1 -@str.347 = private unnamed_addr constant [10 x i8] c"b.get={}\0A\00", align 1 -@str.348 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.347 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.348 = private unnamed_addr constant [10 x i8] c"a.get={}\0A\00", align 1 @str.349 = private unnamed_addr constant [10 x i8] c"b.get={}\0A\00", align 1 -@str.350 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.350 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.351 = private unnamed_addr constant [10 x i8] c"b.get={}\0A\00", align 1 +@str.352 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.353 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.354 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.355 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.354 = private constant [5 x i8] c"line\00" -@fld.str.355 = private constant [4 x i8] c"col\00" -@fld.str.356 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.354, i64 4 }, { ptr, i64 } { ptr @fld.str.355, i64 3 }, { ptr, i64 } { ptr @fld.str.356, i64 4 }] -@str.357 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.358 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.361 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.362 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.364 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.367 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.368 = private constant [12 x i8] c"alloc_count\00" -@field_names.369 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 11 }] -@str.370 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.371 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.372 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.374 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.375 = private constant [5 x i8] c"next\00" -@fld.str.376 = private constant [4 x i8] c"cap\00" -@field_names.377 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.375, i64 4 }, { ptr, i64 } { ptr @fld.str.376, i64 3 }] -@str.378 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.379 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.380 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.381 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.382 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.383 = private constant [4 x i8] c"ctx\00" -@fld.str.384 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.385 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.386 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.383, i64 3 }, { ptr, i64 } { ptr @fld.str.384, i64 11 }, { ptr, i64 } { ptr @fld.str.385, i64 13 }] -@str.387 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.388 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.389 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.390 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.391 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.392 = private constant [6 x i8] c"first\00" -@fld.str.393 = private constant [10 x i8] c"end_index\00" -@fld.str.394 = private constant [7 x i8] c"parent\00" -@field_names.395 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.392, i64 5 }, { ptr, i64 } { ptr @fld.str.393, i64 9 }, { ptr, i64 } { ptr @fld.str.394, i64 6 }] -@str.396 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.397 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.398 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.399 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.400 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.401 = private constant [4 x i8] c"buf\00" -@fld.str.402 = private constant [4 x i8] c"len\00" -@fld.str.403 = private constant [4 x i8] c"pos\00" -@field_names.404 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.401, i64 3 }, { ptr, i64 } { ptr @fld.str.402, i64 3 }, { ptr, i64 } { ptr @fld.str.403, i64 3 }] -@str.405 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.406 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.407 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.408 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.409 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.410 = private constant [7 x i8] c"parent\00" -@fld.str.411 = private constant [12 x i8] c"alloc_count\00" -@fld.str.412 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.413 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.414 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.410, i64 6 }, { ptr, i64 } { ptr @fld.str.411, i64 11 }, { ptr, i64 } { ptr @fld.str.412, i64 13 }, { ptr, i64 } { ptr @fld.str.413, i64 17 }] -@str.415 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.416 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.417 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.419 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.420 = private constant [10 x i8] c"allocator\00" -@fld.str.421 = private constant [5 x i8] c"data\00" -@field_names.422 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.420, i64 9 }, { ptr, i64 } { ptr @fld.str.421, i64 4 }] -@str.423 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.424 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.425 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.426 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.427 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.428 = private constant [3 x i8] c"fd\00" -@field_names.429 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.428, i64 2 }] -@str.430 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.431 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.432 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.433 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.434 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.435 = private constant [5 x i8] c"file\00" -@fld.str.436 = private constant [5 x i8] c"line\00" -@fld.str.437 = private constant [4 x i8] c"col\00" -@fld.str.438 = private constant [5 x i8] c"func\00" -@fld.str.439 = private constant [10 x i8] c"line_text\00" -@field_names.440 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.435, i64 4 }, { ptr, i64 } { ptr @fld.str.436, i64 4 }, { ptr, i64 } { ptr @fld.str.437, i64 3 }, { ptr, i64 } { ptr @fld.str.438, i64 4 }, { ptr, i64 } { ptr @fld.str.439, i64 9 }] -@str.441 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.442 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.443 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.444 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.445 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.446 = private constant [10 x i8] c"exit_code\00" -@fld.str.447 = private constant [7 x i8] c"stdout\00" -@field_names.448 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.446, i64 9 }, { ptr, i64 } { ptr @fld.str.447, i64 6 }] -@str.449 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.450 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.452 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.453 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.454 = private constant [8 x i8] c"sin_len\00" -@fld.str.455 = private constant [11 x i8] c"sin_family\00" -@fld.str.456 = private constant [9 x i8] c"sin_port\00" -@fld.str.457 = private constant [9 x i8] c"sin_addr\00" -@fld.str.458 = private constant [9 x i8] c"sin_zero\00" -@field_names.459 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.454, i64 7 }, { ptr, i64 } { ptr @fld.str.455, i64 10 }, { ptr, i64 } { ptr @fld.str.456, i64 8 }, { ptr, i64 } { ptr @fld.str.457, i64 8 }, { ptr, i64 } { ptr @fld.str.458, i64 8 }] -@str.460 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.461 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.462 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.463 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.464 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.465 = private constant [6 x i8] c"items\00" -@fld.str.466 = private constant [4 x i8] c"len\00" -@fld.str.467 = private constant [4 x i8] c"cap\00" -@field_names.468 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.465, i64 5 }, { ptr, i64 } { ptr @fld.str.466, i64 3 }, { ptr, i64 } { ptr @fld.str.467, i64 3 }] -@str.469 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.470 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.471 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.473 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.474 = private constant [6 x i8] c"items\00" -@fld.str.475 = private constant [4 x i8] c"len\00" -@fld.str.476 = private constant [4 x i8] c"cap\00" -@field_names.477 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.474, i64 5 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }, { ptr, i64 } { ptr @fld.str.476, i64 3 }] -@str.478 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.479 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.480 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.482 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.483 = private constant [4 x i8] c"key\00" -@fld.str.484 = private constant [4 x i8] c"val\00" -@field_names.485 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 3 }] -@str.486 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.487 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.488 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.489 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.490 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.491 = private constant [4 x i8] c"dst\00" -@fld.str.492 = private constant [4 x i8] c"pos\00" -@fld.str.493 = private constant [5 x i8] c"file\00" -@field_names.494 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.491, i64 3 }, { ptr, i64 } { ptr @fld.str.492, i64 3 }, { ptr, i64 } { ptr @fld.str.493, i64 4 }] -@str.495 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.496 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.497 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.499 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.500 = private constant [4 x i8] c"src\00" -@fld.str.501 = private constant [4 x i8] c"pos\00" -@fld.str.502 = private constant [6 x i8] c"alloc\00" -@field_names.503 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.500, i64 3 }, { ptr, i64 } { ptr @fld.str.501, i64 3 }, { ptr, i64 } { ptr @fld.str.502, i64 5 }] -@str.504 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.505 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.508 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.509 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.510 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.511 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.512 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.513 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.514 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.515 = private constant [5 x i8] c"name\00" -@fld.str.516 = private constant [12 x i8] c"takes_value\00" -@fld.str.517 = private constant [9 x i8] c"required\00" -@field_names.518 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.515, i64 4 }, { ptr, i64 } { ptr @fld.str.516, i64 11 }, { ptr, i64 } { ptr @fld.str.517, i64 8 }] -@str.519 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.520 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.521 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.522 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.523 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.524 = private constant [6 x i8] c"group\00" -@fld.str.525 = private constant [8 x i8] c"command\00" -@fld.str.526 = private constant [6 x i8] c"flags\00" -@field_names.527 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.524, i64 5 }, { ptr, i64 } { ptr @fld.str.525, i64 7 }, { ptr, i64 } { ptr @fld.str.526, i64 5 }] -@str.528 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.529 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.530 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.532 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.533 = private constant [4 x i8] c"set\00" -@fld.str.534 = private constant [6 x i8] c"value\00" -@field_names.535 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.533, i64 3 }, { ptr, i64 } { ptr @fld.str.534, i64 5 }] -@str.536 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.537 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.540 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.541 = private constant [6 x i8] c"index\00" -@fld.str.542 = private constant [6 x i8] c"token\00" -@field_names.543 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.541, i64 5 }, { ptr, i64 } { ptr @fld.str.542, i64 5 }] -@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.545 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.548 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.549 = private constant [6 x i8] c"group\00" -@fld.str.550 = private constant [8 x i8] c"command\00" -@fld.str.551 = private constant [10 x i8] c"cmd_index\00" -@fld.str.552 = private constant [5 x i8] c"json\00" -@fld.str.553 = private constant [5 x i8] c"rest\00" -@fld.str.554 = private constant [5 x i8] c"spec\00" -@fld.str.555 = private constant [7 x i8] c"values\00" -@field_names.556 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.549, i64 5 }, { ptr, i64 } { ptr @fld.str.550, i64 7 }, { ptr, i64 } { ptr @fld.str.551, i64 9 }, { ptr, i64 } { ptr @fld.str.552, i64 4 }, { ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 4 }, { ptr, i64 } { ptr @fld.str.555, i64 6 }] -@str.557 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.558 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.559 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.561 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.562 = private constant [2 x i8] c"h\00" -@fld.str.563 = private constant [4 x i8] c"buf\00" -@fld.str.564 = private constant [8 x i8] c"buf_len\00" -@fld.str.565 = private constant [10 x i8] c"total_len\00" -@field_names.566 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 1 }, { ptr, i64 } { ptr @fld.str.563, i64 3 }, { ptr, i64 } { ptr @fld.str.564, i64 7 }, { ptr, i64 } { ptr @fld.str.565, i64 9 }] -@str.567 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.568 = private unnamed_addr constant [8 x i8] c"IntCell\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.570 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.571 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.572 = private constant [2 x i8] c"v\00" -@field_names.573 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 1 }] -@str.574 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.575 = private unnamed_addr constant [8 x i8] c"StrCell\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.578 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.579 = private constant [2 x i8] c"s\00" -@field_names.580 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 1 }] -@str.581 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.582 = private unnamed_addr constant [8 x i8] c"VL__s64\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.585 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.586 = private constant [4 x i8] c"ctx\00" -@fld.str.587 = private constant [9 x i8] c"__vtable\00" -@field_names.588 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 8 }] -@str.589 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.590 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.592 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.593 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.594 = private constant [4 x i8] c"get\00" -@field_names.595 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.594, i64 3 }] -@str.596 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.597 = private unnamed_addr constant [11 x i8] c"VL__string\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.601 = private constant [4 x i8] c"ctx\00" -@fld.str.602 = private constant [9 x i8] c"__vtable\00" -@field_names.603 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.601, i64 3 }, { ptr, i64 } { ptr @fld.str.602, i64 8 }] -@str.604 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.605 = private unnamed_addr constant [21 x i8] c"__VL__string__Vtable\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.609 = private constant [4 x i8] c"get\00" -@field_names.610 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.609, i64 3 }] -@str.611 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.613 = private constant [5 x i8] c"read\00" -@fld.str.614 = private constant [6 x i8] c"write\00" -@fld.str.615 = private constant [7 x i8] c"append\00" -@fld.str.616 = private constant [11 x i8] c"read_write\00" -@field_names.617 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.613, i64 4 }, { ptr, i64 } { ptr @fld.str.614, i64 5 }, { ptr, i64 } { ptr @fld.str.615, i64 6 }, { ptr, i64 } { ptr @fld.str.616, i64 10 }] -@str.618 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.621 = private constant [4 x i8] c"set\00" -@fld.str.622 = private constant [8 x i8] c"current\00" -@fld.str.623 = private constant [4 x i8] c"end\00" -@field_names.624 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.621, i64 3 }, { ptr, i64 } { ptr @fld.str.622, i64 7 }, { ptr, i64 } { ptr @fld.str.623, i64 3 }] -@str.625 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.628 = private constant [6 x i8] c"null_\00" -@fld.str.629 = private constant [6 x i8] c"bool_\00" -@fld.str.630 = private constant [5 x i8] c"int_\00" -@fld.str.631 = private constant [4 x i8] c"str\00" -@fld.str.632 = private constant [6 x i8] c"array\00" -@fld.str.633 = private constant [7 x i8] c"object\00" -@field_names.634 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.628, i64 5 }, { ptr, i64 } { ptr @fld.str.629, i64 5 }, { ptr, i64 } { ptr @fld.str.630, i64 4 }, { ptr, i64 } { ptr @fld.str.631, i64 3 }, { ptr, i64 } { ptr @fld.str.632, i64 5 }, { ptr, i64 } { ptr @fld.str.633, i64 6 }] -@str.635 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.638 = private constant [6 x i8] c"macos\00" -@fld.str.639 = private constant [6 x i8] c"linux\00" -@fld.str.640 = private constant [8 x i8] c"windows\00" -@fld.str.641 = private constant [5 x i8] c"wasm\00" -@fld.str.642 = private constant [4 x i8] c"ios\00" -@fld.str.643 = private constant [8 x i8] c"android\00" -@fld.str.644 = private constant [8 x i8] c"unknown\00" -@field_names.645 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.638, i64 5 }, { ptr, i64 } { ptr @fld.str.639, i64 5 }, { ptr, i64 } { ptr @fld.str.640, i64 7 }, { ptr, i64 } { ptr @fld.str.641, i64 4 }, { ptr, i64 } { ptr @fld.str.642, i64 3 }, { ptr, i64 } { ptr @fld.str.643, i64 7 }, { ptr, i64 } { ptr @fld.str.644, i64 7 }] -@str.646 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.647 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.648 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.649 = private constant [8 x i8] c"aarch64\00" -@fld.str.650 = private constant [7 x i8] c"x86_64\00" -@fld.str.651 = private constant [7 x i8] c"wasm32\00" -@fld.str.652 = private constant [7 x i8] c"wasm64\00" -@fld.str.653 = private constant [8 x i8] c"unknown\00" -@field_names.654 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.649, i64 7 }, { ptr, i64 } { ptr @fld.str.650, i64 6 }, { ptr, i64 } { ptr @fld.str.651, i64 6 }, { ptr, i64 } { ptr @fld.str.652, i64 6 }, { ptr, i64 } { ptr @fld.str.653, i64 7 }] -@str.655 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.656 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.657 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.658 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.659 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.660 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.661 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.662 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.663 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.664 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.665 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.667 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.668 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.669 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.670 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.671 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.672 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.673 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.674 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.676 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.677 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.678 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.679 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.680 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.681 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.682 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.683 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.684 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.685 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.686 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.687 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.688 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.691 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.694 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.700 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.703 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.706 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.709 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.736 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.737 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.739 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.740 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.742 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.743 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.745 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.746 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.748 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.749 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.750 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.751 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.752 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.753 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.754 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.755 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.756 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.757 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.758 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.759 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.760 = private unnamed_addr constant [9 x i8] c"*IntCell\00", align 1 -@str.761 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.762 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.763 = private unnamed_addr constant [9 x i8] c"*StrCell\00", align 1 -@str.764 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.765 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.766 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.767 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.768 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.769 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.770 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.771 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.772 = private unnamed_addr constant [9 x i8] c"*VL__s64\00", align 1 -@str.773 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.774 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.775 = private unnamed_addr constant [10 x i8] c"**IntCell\00", align 1 -@str.776 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.777 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.778 = private unnamed_addr constant [19 x i8] c"*__VL__s64__Vtable\00", align 1 -@str.779 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.780 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.781 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.782 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.783 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.784 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.785 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.787 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.788 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.790 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.791 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.792 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.793 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.794 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.795 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.796 = private unnamed_addr constant [12 x i8] c"*VL__string\00", align 1 -@str.797 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.798 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.799 = private unnamed_addr constant [10 x i8] c"**StrCell\00", align 1 -@str.800 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.801 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.802 = private unnamed_addr constant [22 x i8] c"*__VL__string__Vtable\00", align 1 -@str.803 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.804 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.805 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.356 = private constant [5 x i8] c"line\00" +@fld.str.357 = private constant [4 x i8] c"col\00" +@fld.str.358 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.356, i64 4 }, { ptr, i64 } { ptr @fld.str.357, i64 3 }, { ptr, i64 } { ptr @fld.str.358, i64 4 }] +@str.359 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.360 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.361 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.363 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.364 = private constant [4 x i8] c"ctx\00" +@fld.str.365 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.366 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.367 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.364, i64 3 }, { ptr, i64 } { ptr @fld.str.365, i64 11 }, { ptr, i64 } { ptr @fld.str.366, i64 13 }] +@str.368 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.369 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.372 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.373 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.374 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.375 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.378 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.379 = private constant [12 x i8] c"alloc_count\00" +@field_names.380 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.379, i64 11 }] +@str.381 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.382 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.383 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.385 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.386 = private constant [5 x i8] c"next\00" +@fld.str.387 = private constant [4 x i8] c"cap\00" +@field_names.388 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.386, i64 4 }, { ptr, i64 } { ptr @fld.str.387, i64 3 }] +@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.390 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.394 = private constant [6 x i8] c"first\00" +@fld.str.395 = private constant [10 x i8] c"end_index\00" +@fld.str.396 = private constant [7 x i8] c"parent\00" +@field_names.397 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 5 }, { ptr, i64 } { ptr @fld.str.395, i64 9 }, { ptr, i64 } { ptr @fld.str.396, i64 6 }] +@str.398 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.399 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.401 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.402 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.403 = private constant [4 x i8] c"buf\00" +@fld.str.404 = private constant [4 x i8] c"len\00" +@fld.str.405 = private constant [4 x i8] c"pos\00" +@field_names.406 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.403, i64 3 }, { ptr, i64 } { ptr @fld.str.404, i64 3 }, { ptr, i64 } { ptr @fld.str.405, i64 3 }] +@str.407 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.408 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.409 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.410 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.411 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.412 = private constant [7 x i8] c"parent\00" +@fld.str.413 = private constant [12 x i8] c"alloc_count\00" +@fld.str.414 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.415 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.416 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.412, i64 6 }, { ptr, i64 } { ptr @fld.str.413, i64 11 }, { ptr, i64 } { ptr @fld.str.414, i64 13 }, { ptr, i64 } { ptr @fld.str.415, i64 17 }] +@str.417 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.418 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.419 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.421 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.422 = private constant [10 x i8] c"allocator\00" +@fld.str.423 = private constant [5 x i8] c"data\00" +@field_names.424 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.422, i64 9 }, { ptr, i64 } { ptr @fld.str.423, i64 4 }] +@str.425 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.426 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.427 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.428 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.429 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.430 = private constant [3 x i8] c"fd\00" +@field_names.431 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.430, i64 2 }] +@str.432 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.433 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.434 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.435 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.436 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.437 = private constant [5 x i8] c"file\00" +@fld.str.438 = private constant [5 x i8] c"line\00" +@fld.str.439 = private constant [4 x i8] c"col\00" +@fld.str.440 = private constant [5 x i8] c"func\00" +@fld.str.441 = private constant [10 x i8] c"line_text\00" +@field_names.442 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.437, i64 4 }, { ptr, i64 } { ptr @fld.str.438, i64 4 }, { ptr, i64 } { ptr @fld.str.439, i64 3 }, { ptr, i64 } { ptr @fld.str.440, i64 4 }, { ptr, i64 } { ptr @fld.str.441, i64 9 }] +@str.443 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.444 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.445 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.446 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.447 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.448 = private constant [10 x i8] c"exit_code\00" +@fld.str.449 = private constant [7 x i8] c"stdout\00" +@field_names.450 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.448, i64 9 }, { ptr, i64 } { ptr @fld.str.449, i64 6 }] +@str.451 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.452 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.454 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.455 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.456 = private constant [8 x i8] c"sin_len\00" +@fld.str.457 = private constant [11 x i8] c"sin_family\00" +@fld.str.458 = private constant [9 x i8] c"sin_port\00" +@fld.str.459 = private constant [9 x i8] c"sin_addr\00" +@fld.str.460 = private constant [9 x i8] c"sin_zero\00" +@field_names.461 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.456, i64 7 }, { ptr, i64 } { ptr @fld.str.457, i64 10 }, { ptr, i64 } { ptr @fld.str.458, i64 8 }, { ptr, i64 } { ptr @fld.str.459, i64 8 }, { ptr, i64 } { ptr @fld.str.460, i64 8 }] +@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.463 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.467 = private constant [6 x i8] c"items\00" +@fld.str.468 = private constant [4 x i8] c"len\00" +@fld.str.469 = private constant [4 x i8] c"cap\00" +@field_names.470 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 5 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }] +@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.472 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.476 = private constant [6 x i8] c"items\00" +@fld.str.477 = private constant [4 x i8] c"len\00" +@fld.str.478 = private constant [4 x i8] c"cap\00" +@field_names.479 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 5 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }] +@str.480 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.481 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.482 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.484 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.485 = private constant [4 x i8] c"key\00" +@fld.str.486 = private constant [4 x i8] c"val\00" +@field_names.487 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 3 }] +@str.488 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.489 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.490 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.491 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.492 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.493 = private constant [4 x i8] c"dst\00" +@fld.str.494 = private constant [4 x i8] c"pos\00" +@fld.str.495 = private constant [5 x i8] c"file\00" +@field_names.496 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 3 }, { ptr, i64 } { ptr @fld.str.495, i64 4 }] +@str.497 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.498 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.499 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.501 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.502 = private constant [4 x i8] c"src\00" +@fld.str.503 = private constant [4 x i8] c"pos\00" +@fld.str.504 = private constant [6 x i8] c"alloc\00" +@field_names.505 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.502, i64 3 }, { ptr, i64 } { ptr @fld.str.503, i64 3 }, { ptr, i64 } { ptr @fld.str.504, i64 5 }] +@str.506 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.507 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.510 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.511 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.513 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.514 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.515 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.516 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.517 = private constant [5 x i8] c"name\00" +@fld.str.518 = private constant [12 x i8] c"takes_value\00" +@fld.str.519 = private constant [9 x i8] c"required\00" +@field_names.520 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.517, i64 4 }, { ptr, i64 } { ptr @fld.str.518, i64 11 }, { ptr, i64 } { ptr @fld.str.519, i64 8 }] +@str.521 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.522 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.523 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.524 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.525 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.526 = private constant [6 x i8] c"group\00" +@fld.str.527 = private constant [8 x i8] c"command\00" +@fld.str.528 = private constant [6 x i8] c"flags\00" +@field_names.529 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.526, i64 5 }, { ptr, i64 } { ptr @fld.str.527, i64 7 }, { ptr, i64 } { ptr @fld.str.528, i64 5 }] +@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.531 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.532 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.534 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.535 = private constant [4 x i8] c"set\00" +@fld.str.536 = private constant [6 x i8] c"value\00" +@field_names.537 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 3 }, { ptr, i64 } { ptr @fld.str.536, i64 5 }] +@str.538 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.539 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.542 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.543 = private constant [6 x i8] c"index\00" +@fld.str.544 = private constant [6 x i8] c"token\00" +@field_names.545 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.543, i64 5 }, { ptr, i64 } { ptr @fld.str.544, i64 5 }] +@str.546 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.547 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.550 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.551 = private constant [6 x i8] c"group\00" +@fld.str.552 = private constant [8 x i8] c"command\00" +@fld.str.553 = private constant [10 x i8] c"cmd_index\00" +@fld.str.554 = private constant [5 x i8] c"json\00" +@fld.str.555 = private constant [5 x i8] c"rest\00" +@fld.str.556 = private constant [5 x i8] c"spec\00" +@fld.str.557 = private constant [7 x i8] c"values\00" +@field_names.558 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.551, i64 5 }, { ptr, i64 } { ptr @fld.str.552, i64 7 }, { ptr, i64 } { ptr @fld.str.553, i64 9 }, { ptr, i64 } { ptr @fld.str.554, i64 4 }, { ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 4 }, { ptr, i64 } { ptr @fld.str.557, i64 6 }] +@str.559 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.560 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.561 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.563 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.564 = private constant [2 x i8] c"h\00" +@fld.str.565 = private constant [4 x i8] c"buf\00" +@fld.str.566 = private constant [8 x i8] c"buf_len\00" +@fld.str.567 = private constant [10 x i8] c"total_len\00" +@field_names.568 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 1 }, { ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 7 }, { ptr, i64 } { ptr @fld.str.567, i64 9 }] +@str.569 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.570 = private unnamed_addr constant [8 x i8] c"IntCell\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.572 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.573 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.574 = private constant [2 x i8] c"v\00" +@field_names.575 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 1 }] +@str.576 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.577 = private unnamed_addr constant [8 x i8] c"StrCell\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.580 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.581 = private constant [2 x i8] c"s\00" +@field_names.582 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 1 }] +@str.583 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.584 = private unnamed_addr constant [8 x i8] c"VL__s64\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.587 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.588 = private constant [4 x i8] c"ctx\00" +@fld.str.589 = private constant [9 x i8] c"__vtable\00" +@field_names.590 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.588, i64 3 }, { ptr, i64 } { ptr @fld.str.589, i64 8 }] +@str.591 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.592 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.594 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.595 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.596 = private constant [4 x i8] c"get\00" +@field_names.597 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.596, i64 3 }] +@str.598 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.599 = private unnamed_addr constant [11 x i8] c"VL__string\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.602 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.603 = private constant [4 x i8] c"ctx\00" +@fld.str.604 = private constant [9 x i8] c"__vtable\00" +@field_names.605 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.603, i64 3 }, { ptr, i64 } { ptr @fld.str.604, i64 8 }] +@str.606 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.607 = private unnamed_addr constant [21 x i8] c"__VL__string__Vtable\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.611 = private constant [4 x i8] c"get\00" +@field_names.612 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.611, i64 3 }] +@str.613 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.615 = private constant [5 x i8] c"read\00" +@fld.str.616 = private constant [6 x i8] c"write\00" +@fld.str.617 = private constant [7 x i8] c"append\00" +@fld.str.618 = private constant [11 x i8] c"read_write\00" +@field_names.619 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.615, i64 4 }, { ptr, i64 } { ptr @fld.str.616, i64 5 }, { ptr, i64 } { ptr @fld.str.617, i64 6 }, { ptr, i64 } { ptr @fld.str.618, i64 10 }] +@str.620 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.623 = private constant [4 x i8] c"set\00" +@fld.str.624 = private constant [8 x i8] c"current\00" +@fld.str.625 = private constant [4 x i8] c"end\00" +@field_names.626 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.623, i64 3 }, { ptr, i64 } { ptr @fld.str.624, i64 7 }, { ptr, i64 } { ptr @fld.str.625, i64 3 }] +@str.627 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.630 = private constant [6 x i8] c"null_\00" +@fld.str.631 = private constant [6 x i8] c"bool_\00" +@fld.str.632 = private constant [5 x i8] c"int_\00" +@fld.str.633 = private constant [4 x i8] c"str\00" +@fld.str.634 = private constant [6 x i8] c"array\00" +@fld.str.635 = private constant [7 x i8] c"object\00" +@field_names.636 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.630, i64 5 }, { ptr, i64 } { ptr @fld.str.631, i64 5 }, { ptr, i64 } { ptr @fld.str.632, i64 4 }, { ptr, i64 } { ptr @fld.str.633, i64 3 }, { ptr, i64 } { ptr @fld.str.634, i64 5 }, { ptr, i64 } { ptr @fld.str.635, i64 6 }] +@str.637 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.640 = private constant [6 x i8] c"macos\00" +@fld.str.641 = private constant [6 x i8] c"linux\00" +@fld.str.642 = private constant [8 x i8] c"windows\00" +@fld.str.643 = private constant [5 x i8] c"wasm\00" +@fld.str.644 = private constant [4 x i8] c"ios\00" +@fld.str.645 = private constant [8 x i8] c"android\00" +@fld.str.646 = private constant [8 x i8] c"unknown\00" +@field_names.647 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.640, i64 5 }, { ptr, i64 } { ptr @fld.str.641, i64 5 }, { ptr, i64 } { ptr @fld.str.642, i64 7 }, { ptr, i64 } { ptr @fld.str.643, i64 4 }, { ptr, i64 } { ptr @fld.str.644, i64 3 }, { ptr, i64 } { ptr @fld.str.645, i64 7 }, { ptr, i64 } { ptr @fld.str.646, i64 7 }] +@str.648 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.649 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.650 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.651 = private constant [8 x i8] c"aarch64\00" +@fld.str.652 = private constant [7 x i8] c"x86_64\00" +@fld.str.653 = private constant [7 x i8] c"wasm32\00" +@fld.str.654 = private constant [7 x i8] c"wasm64\00" +@fld.str.655 = private constant [8 x i8] c"unknown\00" +@field_names.656 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.651, i64 7 }, { ptr, i64 } { ptr @fld.str.652, i64 6 }, { ptr, i64 } { ptr @fld.str.653, i64 6 }, { ptr, i64 } { ptr @fld.str.654, i64 6 }, { ptr, i64 } { ptr @fld.str.655, i64 7 }] +@str.657 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.658 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.659 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.660 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.661 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.662 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.663 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.664 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.665 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.666 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.669 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.670 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.671 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.672 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.673 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.674 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.675 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.678 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.679 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.680 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.681 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.682 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.683 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.684 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.685 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.686 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.687 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.688 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.689 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.690 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.691 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.693 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.696 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.702 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.705 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.708 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.711 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.735 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.741 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.742 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.744 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.745 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.747 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.750 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.753 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.756 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.759 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.762 = private unnamed_addr constant [9 x i8] c"*IntCell\00", align 1 +@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.765 = private unnamed_addr constant [9 x i8] c"*StrCell\00", align 1 +@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.768 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.771 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.774 = private unnamed_addr constant [9 x i8] c"*VL__s64\00", align 1 +@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.777 = private unnamed_addr constant [10 x i8] c"**IntCell\00", align 1 +@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.780 = private unnamed_addr constant [19 x i8] c"*__VL__s64__Vtable\00", align 1 +@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.783 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.786 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.787 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.789 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.790 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.791 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.792 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.793 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.795 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.796 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.798 = private unnamed_addr constant [12 x i8] c"*VL__string\00", align 1 +@str.799 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.800 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.801 = private unnamed_addr constant [10 x i8] c"**StrCell\00", align 1 +@str.802 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.803 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.804 = private unnamed_addr constant [22 x i8] c"*__VL__string__Vtable\00", align 1 +@str.805 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.806 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.807 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.808 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.809 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -705,6 +705,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -924,7 +927,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1051,7 +1054,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1385,7 +1388,7 @@ entry: br i1 %icmp, label %if.then.412, label %if.merge.413 if.then.412: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.413: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1535,7 +1538,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1561,9 +1564,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1610,9 +1613,9 @@ entry: i64 85, label %match.arm.48 i64 105, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1659,7 +1662,7 @@ match.merge.37: ; preds = %dispatch.merge.536, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1703,9 +1706,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1792,9 +1795,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.370 [ i64 18, label %dispatch.case.371 - i64 21, label %dispatch.case.372 - i64 23, label %dispatch.case.373 - i64 25, label %dispatch.case.374 + i64 22, label %dispatch.case.372 + i64 24, label %dispatch.case.373 + i64 26, label %dispatch.case.374 i64 28, label %dispatch.case.375 i64 29, label %dispatch.case.376 i64 31, label %dispatch.case.377 @@ -1899,7 +1902,7 @@ dispatch.merge.94: ; preds = %dispatch.case.126, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.322, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1913,32 +1916,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2156,7 +2159,7 @@ dispatch.merge.282: ; preds = %dispatch.case.288, br label %match.merge.37 dispatch.default.283: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.282 dispatch.case.284: ; preds = %match.arm.44 @@ -2197,7 +2200,7 @@ dispatch.merge.299: ; preds = %dispatch.case.306, br label %match.merge.37 dispatch.default.300: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.299 dispatch.case.301: ; preds = %match.arm.47 @@ -2254,7 +2257,7 @@ dispatch.merge.337: ; preds = %dispatch.case.343, br label %match.merge.37 dispatch.default.338: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.337 dispatch.case.339: ; preds = %match.arm.48 @@ -2303,7 +2306,7 @@ dispatch.merge.369: ; preds = %dispatch.case.408, br label %match.merge.37 dispatch.default.370: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.369 dispatch.case.371: ; preds = %match.arm.49 @@ -2578,7 +2581,7 @@ dispatch.merge.536: ; preds = %dispatch.case.541, br label %match.merge.37 dispatch.default.537: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.536 dispatch.case.538: ; preds = %match.arm.50 @@ -2620,7 +2623,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.328, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.330, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2716,7 +2719,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2724,7 +2727,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2734,13 +2737,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2748,7 +2751,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2762,7 +2765,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2770,7 +2773,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2781,7 +2784,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2838,7 +2841,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2846,7 +2849,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2857,7 +2860,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2877,7 +2880,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2885,7 +2888,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, 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 @@ -2896,7 +2899,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2906,64 +2909,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3139,163 +3145,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3493,64 +3502,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3580,97 +3589,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3709,7 +3718,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @IntCell.get(ptr %0, ptr %1) #0 { @@ -3757,7 +3766,7 @@ entry: call void @print__ct_seb9f5db11fd9fc4e__pack_s64(ptr @__sx_default_context, i64 %icallN) %allocaN = alloca { ptr, ptr }, align 8 %allocaN = alloca { { ptr, i64 } }, align 8 - store { { ptr, i64 } } { { ptr, i64 } { ptr @str.343, i64 2 } }, ptr %allocaN, align 8 + store { { ptr, i64 } } { { ptr, i64 } { ptr @str.345, i64 2 } }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, ptr }, ptr @__sx_default_context, align 8 %sgN = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 %sgN = extractvalue { ptr, ptr, ptr } %sgN, 0 @@ -3802,7 +3811,7 @@ entry: define internal void @print__ct_seb9f5db11fd9fc4e__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.344, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.346, i64 9 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3817,7 +3826,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.345, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.347, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -3844,7 +3853,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.346, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.348, i64 9 }) ret { ptr, i64 } %call } @@ -3859,7 +3868,7 @@ entry: define internal void @print__ct_sfd7f12a0a81d0d1c__pack_string(ptr %0, { ptr, i64 } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.347, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.349, i64 9 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3877,7 +3886,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.348, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.350, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 6) @@ -3907,7 +3916,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.349, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.351, i64 9 }) ret { ptr, i64 } %call } @@ -3918,7 +3927,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 15 }, { ptr, i64 } { ptr @str.351, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.352, i64 15 }, { ptr, i64 } { ptr @str.353, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3937,12 +3946,12 @@ while.body.128: ; preds = %while.hdr.127 while.exit.129: ; preds = %while.hdr.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 1 }) ret { ptr, i64 } %callN if.then.130: ; preds = %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.131 @@ -3954,7 +3963,7 @@ if.merge.131: ; preds = %if.then.130, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4007,20 +4016,20 @@ fv.case24: ; preds = %if.merge.131 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.358, i64 10 }, { ptr, i64 } { ptr @str.359, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.360, i64 9 }, { ptr, i64 } { ptr @str.361, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.132 -while.hdr.132: ; preds = %if.merge.136, %entry +while.hdr.132: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.133, label %while.exit.134 while.body.133: ; preds = %while.hdr.132 @@ -4030,224 +4039,24 @@ while.body.133: ; preds = %while.hdr.132 while.exit.134: ; preds = %while.hdr.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 1 }) ret { ptr, i64 } %callN if.then.135: ; preds = %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.136 if.merge.136: ; preds = %if.then.135, %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.362, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.367, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.132 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.364, i64 3 }, { ptr, i64 } { ptr @str.365, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.137 - -while.hdr.137: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.138, label %while.exit.139 - -while.body.138: ; preds = %while.hdr.137 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.140, label %if.merge.141 - -while.exit.139: ; preds = %while.hdr.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 1 }) - ret { ptr, i64 } %callN - -if.then.140: ; preds = %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.141 - -if.merge.141: ; preds = %if.then.140, %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.369, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 - -fv.default: ; preds = %if.merge.141 - br label %fv.merge - -fv.case: ; preds = %if.merge.141 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.371, i64 10 }, { ptr, i64 } { ptr @str.372, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 - -while.hdr.142: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.143, label %while.exit.144 - -while.body.143: ; preds = %while.hdr.142 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 - -while.exit.144: ; preds = %while.hdr.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) - ret { ptr, i64 } %callN - -if.then.145: ; preds = %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 - -if.merge.146: ; preds = %if.then.145, %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.377, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 - -fv.default: ; preds = %if.merge.146 - br label %fv.merge - -fv.case: ; preds = %if.merge.146 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.146 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 9 }, { ptr, i64 } { ptr @str.380, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 - -while.hdr.147: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.148, label %while.exit.149 - -while.body.148: ; preds = %while.hdr.147 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 - -while.exit.149: ; preds = %while.hdr.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 1 }) - ret { ptr, i64 } %callN - -if.then.150: ; preds = %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 - -if.merge.151: ; preds = %if.then.150, %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.386, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, 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 @@ -4266,27 +4075,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.132 + +fv.default: ; preds = %if.merge.136 + br label %fv.merge + +fv.case: ; preds = %if.merge.136 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.136 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.136 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.369, i64 10 }, { ptr, i64 } { ptr @str.370, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.137 + +while.hdr.137: ; preds = %if.merge.141, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.138, label %while.exit.139 + +while.body.138: ; preds = %while.hdr.137 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.140, label %if.merge.141 + +while.exit.139: ; preds = %while.hdr.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 1 }) + ret { ptr, i64 } %callN + +if.then.140: ; preds = %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.141 + +if.merge.141: ; preds = %if.then.140, %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.373, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.375, i64 3 }, { ptr, i64 } { ptr @str.376, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.142 + +while.hdr.142: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.143, label %while.exit.144 + +while.body.143: ; preds = %while.hdr.142 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.145, label %if.merge.146 + +while.exit.144: ; preds = %while.hdr.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 1 }) + ret { ptr, i64 } %callN + +if.then.145: ; preds = %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.146 + +if.merge.146: ; preds = %if.then.145, %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.380, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.142 + +fv.default: ; preds = %if.merge.146 + br label %fv.merge + +fv.case: ; preds = %if.merge.146 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.382, i64 10 }, { ptr, i64 } { ptr @str.383, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.147 + +while.hdr.147: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.148, label %while.exit.149 + +while.body.148: ; preds = %while.hdr.147 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.150, label %if.merge.151 + +while.exit.149: ; preds = %while.hdr.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 1 }) + ret { ptr, i64 } %callN + +if.then.150: ; preds = %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.151 + +if.merge.151: ; preds = %if.then.150, %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.388, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.147 fv.default: ; preds = %if.merge.151 br label %fv.merge fv.case: ; preds = %if.merge.151 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.151 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.151 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4296,7 +4305,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 5 }, { ptr, i64 } { ptr @str.389, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 5 }, { ptr, i64 } { ptr @str.391, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4315,24 +4324,24 @@ while.body.153: ; preds = %while.hdr.152 while.exit.154: ; preds = %while.hdr.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) ret { ptr, i64 } %callN if.then.155: ; preds = %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.156 if.merge.156: ; preds = %if.then.155, %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.395, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.397, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, 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 @@ -4359,7 +4368,7 @@ fv.default: ; preds = %if.merge.156 fv.case: ; preds = %if.merge.156 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.156 @@ -4371,7 +4380,7 @@ fv.case20: ; preds = %if.merge.156 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4380,7 +4389,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.397, i64 8 }, { ptr, i64 } { ptr @str.398, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 8 }, { ptr, i64 } { ptr @str.400, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4399,24 +4408,24 @@ while.body.158: ; preds = %while.hdr.157 while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 1 }) ret { ptr, i64 } %callN if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.161 if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.404, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.406, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, 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 @@ -4463,7 +4472,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.406, i64 17 }, { ptr, i64 } { ptr @str.407, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.408, i64 17 }, { ptr, i64 } { ptr @str.409, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4482,24 +4491,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.414, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.416, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4528,7 +4537,7 @@ fv.case: ; preds = %if.merge.166 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 @@ -4553,7 +4562,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.416, i64 7 }, { ptr, i64 } { ptr @str.417, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.418, i64 7 }, { ptr, i64 } { ptr @str.419, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4572,24 +4581,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %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.422, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.424, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, 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 @@ -4616,7 +4625,7 @@ fv.case: ; preds = %if.merge.171 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 @@ -4631,7 +4640,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.424, i64 4 }, { ptr, i64 } { ptr @str.425, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 4 }, { ptr, i64 } { ptr @str.427, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4650,24 +4659,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %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.429, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.431, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4704,7 +4713,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.431, i64 10 }, { ptr, i64 } { ptr @str.432, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.433, i64 10 }, { ptr, i64 } { ptr @str.434, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4723,24 +4732,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.440, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.442, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4806,7 +4815,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.442, i64 13 }, { ptr, i64 } { ptr @str.443, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.444, i64 13 }, { ptr, i64 } { ptr @str.445, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4825,24 +4834,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %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.448, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.450, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4884,7 +4893,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.450, i64 8 }, { ptr, i64 } { ptr @str.451, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.452, i64 8 }, { ptr, i64 } { ptr @str.453, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4903,24 +4912,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.459, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.461, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4981,7 +4990,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.461, i64 5 }, { ptr, i64 } { ptr @str.462, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 5 }, { ptr, i64 } { ptr @str.464, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5000,24 +5009,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %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.468, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.470, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, 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 @@ -5063,7 +5072,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.470, i64 6 }, { ptr, i64 } { ptr @str.471, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 6 }, { ptr, i64 } { ptr @str.473, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5082,24 +5091,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %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.477, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.479, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, 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 @@ -5147,7 +5156,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.479, i64 6 }, { ptr, i64 } { ptr @str.480, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.481, i64 6 }, { ptr, i64 } { ptr @str.482, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5166,24 +5175,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.485, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.487, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5227,7 +5236,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.487, i64 4 }, { ptr, i64 } { ptr @str.488, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 4 }, { ptr, i64 } { ptr @str.490, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5246,24 +5255,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.494, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.496, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5313,7 +5322,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.496, i64 6 }, { ptr, i64 } { ptr @str.497, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.498, i64 6 }, { ptr, i64 } { ptr @str.499, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5332,24 +5341,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.503, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.505, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5389,7 +5398,7 @@ fv.case20: ; preds = %if.merge.216 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5398,7 +5407,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.505, i64 12 }, { ptr, i64 } { ptr @str.506, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.507, i64 12 }, { ptr, i64 } { ptr @str.508, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5417,24 +5426,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.509, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.511, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5454,7 +5463,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.511, i64 8 }, { ptr, i64 } { ptr @str.512, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 8 }, { ptr, i64 } { ptr @str.514, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5473,24 +5482,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.518, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.520, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5542,7 +5551,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.520, i64 7 }, { ptr, i64 } { ptr @str.521, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.522, i64 7 }, { ptr, i64 } { ptr @str.523, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5561,24 +5570,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.527, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.529, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5630,7 +5639,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.529, i64 9 }, { ptr, i64 } { ptr @str.530, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 9 }, { ptr, i64 } { ptr @str.532, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5649,24 +5658,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.535, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.537, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5709,7 +5718,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.537, i64 4 }, { ptr, i64 } { ptr @str.538, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.539, i64 4 }, { ptr, i64 } { ptr @str.540, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5728,24 +5737,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %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.543, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.545, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5791,7 +5800,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 6 }, { ptr, i64 } { ptr @str.546, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.547, i64 6 }, { ptr, i64 } { ptr @str.548, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5810,24 +5819,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.556, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.558, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.559, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5909,7 +5918,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, i64 6 }, { ptr, i64 } { ptr @str.559, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 6 }, { ptr, i64 } { ptr @str.561, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5928,24 +5937,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.567, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6000,7 +6009,7 @@ define internal { ptr, i64 } @struct_to_string__IntCell(ptr %0, { i64 } %1) #0 { entry: %alloca = alloca { i64 }, align 8 store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.568, i64 7 }, { ptr, i64 } { ptr @str.569, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.570, i64 7 }, { ptr, i64 } { ptr @str.571, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6019,24 +6028,24 @@ while.body.253: ; preds = %while.hdr.252 while.exit.254: ; preds = %while.hdr.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 1 }) ret { ptr, i64 } %callN if.then.255: ; preds = %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 if.merge.256: ; preds = %if.then.255, %while.body.253 %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.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.576, 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 @@ -6070,7 +6079,7 @@ entry: %alloca = alloca { { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, i64 7 }, { ptr, i64 } { ptr @str.576, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 7 }, { ptr, i64 } { ptr @str.578, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6089,24 +6098,24 @@ while.body.258: ; preds = %while.hdr.257 while.exit.259: ; preds = %while.hdr.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) ret { ptr, i64 } %callN if.then.260: ; preds = %while.body.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.261 if.merge.261: ; preds = %if.then.260, %while.body.258 %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.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.582, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, 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 @@ -6141,7 +6150,7 @@ define internal { ptr, i64 } @struct_to_string__VL__s64(ptr %0, { ptr, ptr } %1) entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, i64 7 }, { ptr, i64 } { ptr @str.583, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 7 }, { ptr, i64 } { ptr @str.585, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6160,24 +6169,24 @@ while.body.263: ; preds = %while.hdr.262 while.exit.264: ; preds = %while.hdr.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.586, i64 1 }) ret { ptr, i64 } %callN if.then.265: ; preds = %while.body.263 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 if.merge.266: ; preds = %if.then.265, %while.body.263 %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.588, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.590, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6218,7 +6227,7 @@ define internal { ptr, i64 } @struct_to_string____VL__s64__Vtable(ptr %0, { ptr entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 17 }, { ptr, i64 } { ptr @str.591, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 17 }, { ptr, i64 } { ptr @str.593, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6237,24 +6246,24 @@ while.body.268: ; preds = %while.hdr.267 while.exit.269: ; preds = %while.hdr.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 1 }) ret { ptr, i64 } %callN if.then.270: ; preds = %while.body.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.271 if.merge.271: ; preds = %if.then.270, %while.body.268 %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.595, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.597, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6288,7 +6297,7 @@ define internal { ptr, i64 } @struct_to_string__VL__string(ptr %0, { ptr, ptr } entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 10 }, { ptr, i64 } { ptr @str.598, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 10 }, { ptr, i64 } { ptr @str.600, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6307,24 +6316,24 @@ while.body.273: ; preds = %while.hdr.272 while.exit.274: ; preds = %while.hdr.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 1 }) ret { ptr, i64 } %callN if.then.275: ; preds = %while.body.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 if.merge.276: ; preds = %if.then.275, %while.body.273 %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.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.605, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6365,7 +6374,7 @@ define internal { ptr, i64 } @struct_to_string____VL__string__Vtable(ptr %0, { p entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.605, i64 20 }, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.607, i64 20 }, { ptr, i64 } { ptr @str.608, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6384,24 +6393,24 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) ret { ptr, i64 } %callN if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 if.merge.281: ; preds = %if.then.280, %while.body.278 %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.610, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.612, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6439,9 +6448,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.617, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.619, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.612, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.614, 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 @@ -6460,8 +6469,8 @@ entry: if.then.289: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.618, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.620, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6480,9 +6489,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.624, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.626, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.620, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.622, 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 @@ -6501,8 +6510,8 @@ entry: if.then.291: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.627, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.292 @@ -6532,9 +6541,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.634, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.636, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.627, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6551,8 +6560,8 @@ entry: if.then.293: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.294 @@ -6630,9 +6639,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.645, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.647, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, 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 @@ -6651,8 +6660,8 @@ entry: if.then.295: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.647, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.649, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6671,9 +6680,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.654, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.656, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, 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 @@ -6692,8 +6701,8 @@ entry: if.then.297: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.656, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.298 @@ -6710,7 +6719,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.657, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.659, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.307 @@ -6727,12 +6736,12 @@ while.body.308: ; preds = %while.hdr.307 while.exit.309: ; preds = %while.hdr.307 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 1 }) ret { ptr, i64 } %call if.then.310: ; preds = %while.body.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.311 @@ -6761,7 +6770,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.660, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.662, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.312 @@ -6778,12 +6787,12 @@ while.body.313: ; preds = %while.hdr.312 while.exit.314: ; preds = %while.hdr.312 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 1 }) ret { ptr, i64 } %call if.then.315: ; preds = %while.body.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.316 @@ -6813,7 +6822,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.663, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.665, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.317 @@ -6830,12 +6839,12 @@ while.body.318: ; preds = %while.hdr.317 while.exit.319: ; preds = %while.hdr.317 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 1 }) ret { ptr, i64 } %call if.then.320: ; preds = %while.body.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.321 @@ -6863,7 +6872,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.666, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.668, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.322 @@ -6880,12 +6889,12 @@ while.body.323: ; preds = %while.hdr.322 while.exit.324: ; preds = %while.hdr.322 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 1 }) ret { ptr, i64 } %call if.then.325: ; preds = %while.body.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.326 @@ -6914,7 +6923,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.669, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.671, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.327 @@ -6931,12 +6940,12 @@ while.body.328: ; preds = %while.hdr.327 while.exit.329: ; preds = %while.hdr.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 1 }) ret { ptr, i64 } %call if.then.330: ; preds = %while.body.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.331 @@ -6965,7 +6974,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.672, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.674, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -6982,12 +6991,12 @@ while.body.333: ; preds = %while.hdr.332 while.exit.334: ; preds = %while.hdr.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 1 }) ret { ptr, i64 } %call if.then.335: ; preds = %while.body.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.336 @@ -7017,7 +7026,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.675, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.677, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.344 @@ -7036,12 +7045,12 @@ while.body.345: ; preds = %while.hdr.344 while.exit.346: ; preds = %while.hdr.344 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 1 }) ret { ptr, i64 } %call if.then.347: ; preds = %while.body.345 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.348 @@ -7070,7 +7079,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.678, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.680, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.349 @@ -7089,12 +7098,12 @@ while.body.350: ; preds = %while.hdr.349 while.exit.351: ; preds = %while.hdr.349 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 1 }) ret { ptr, i64 } %call if.then.352: ; preds = %while.body.350 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.353 @@ -7123,7 +7132,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.681, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.683, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.354 @@ -7142,12 +7151,12 @@ while.body.355: ; preds = %while.hdr.354 while.exit.356: ; preds = %while.hdr.354 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 1 }) ret { ptr, i64 } %call if.then.357: ; preds = %while.body.355 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.358 @@ -7177,7 +7186,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.684, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.686, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.359 @@ -7196,12 +7205,12 @@ while.body.360: ; preds = %while.hdr.359 while.exit.361: ; preds = %while.hdr.359 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 1 }) ret { ptr, i64 } %call if.then.362: ; preds = %while.body.360 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.363 @@ -7231,7 +7240,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.687, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.689, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.364 @@ -7250,12 +7259,12 @@ while.body.365: ; preds = %while.hdr.364 while.exit.366: ; preds = %while.hdr.364 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 1 }) ret { ptr, i64 } %call if.then.367: ; preds = %while.body.365 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.368 @@ -7297,12 +7306,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 5 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -7325,12 +7334,12 @@ if.then.425: ; preds = %entry if.else.426: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 11 }, { ptr, i64 } %callN) br label %if.merge.427 if.merge.427: ; preds = %if.else.426, %if.then.425 - %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -7353,12 +7362,12 @@ if.then.428: ; preds = %entry if.else.429: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 4 }, { ptr, i64 } %callN) br label %if.merge.430 if.merge.430: ; preds = %if.else.429, %if.then.428 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7381,12 +7390,12 @@ if.then.431: ; preds = %entry if.else.432: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 11 }, { ptr, i64 } %callN) br label %if.merge.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7409,12 +7418,12 @@ if.then.434: ; preds = %entry if.else.435: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 6 }, { ptr, i64 } %callN) br label %if.merge.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7436,12 +7445,12 @@ if.then.437: ; preds = %entry if.else.438: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 5 }, { ptr, i64 } %callN) br label %if.merge.439 if.merge.439: ; preds = %if.else.438, %if.then.437 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7464,12 +7473,12 @@ if.then.440: ; preds = %entry if.else.441: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 9 }, { ptr, i64 } %callN) br label %if.merge.442 if.merge.442: ; preds = %if.else.441, %if.then.440 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7492,12 +7501,12 @@ if.then.443: ; preds = %entry if.else.444: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 18 }, { ptr, i64 } %callN) br label %if.merge.445 if.merge.445: ; preds = %if.else.444, %if.then.443 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7520,12 +7529,12 @@ if.then.446: ; preds = %entry if.else.447: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 5 }, { ptr, i64 } %callN) br label %if.merge.448 if.merge.448: ; preds = %if.else.447, %if.then.446 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7548,12 +7557,12 @@ if.then.449: ; preds = %entry if.else.450: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %callN) br label %if.merge.451 if.merge.451: ; preds = %if.else.450, %if.then.449 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7576,12 +7585,12 @@ if.then.452: ; preds = %entry if.else.453: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 4 }, { ptr, i64 } %callN) br label %if.merge.454 if.merge.454: ; preds = %if.else.453, %if.then.452 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7604,12 +7613,12 @@ if.then.455: ; preds = %entry if.else.456: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 9 }, { ptr, i64 } %callN) br label %if.merge.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7632,12 +7641,12 @@ if.then.458: ; preds = %entry if.else.459: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 4 }, { ptr, i64 } %callN) br label %if.merge.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7659,12 +7668,12 @@ if.then.461: ; preds = %entry if.else.462: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 8 }, { ptr, i64 } %callN) br label %if.merge.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7687,12 +7696,12 @@ if.then.464: ; preds = %entry if.else.465: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 6 }, { ptr, i64 } %callN) br label %if.merge.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7714,12 +7723,12 @@ if.then.467: ; preds = %entry if.else.468: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 9 }, { ptr, i64 } %callN) br label %if.merge.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7742,12 +7751,12 @@ if.then.470: ; preds = %entry if.else.471: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 7 }, { ptr, i64 } %callN) br label %if.merge.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7770,12 +7779,12 @@ if.then.473: ; preds = %entry if.else.474: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 5 }, { ptr, i64 } %callN) br label %if.merge.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7798,12 +7807,12 @@ if.then.476: ; preds = %entry if.else.477: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 7 }, { ptr, i64 } %callN) br label %if.merge.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7826,12 +7835,12 @@ if.then.479: ; preds = %entry if.else.480: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 4 }, { ptr, i64 } %callN) br label %if.merge.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7854,12 +7863,12 @@ if.then.482: ; preds = %entry if.else.483: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 7 }, { ptr, i64 } %callN) br label %if.merge.484 if.merge.484: ; preds = %if.else.483, %if.then.482 - %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -7882,12 +7891,12 @@ if.then.485: ; preds = %entry if.else.486: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 5 }, { ptr, i64 } %callN) br label %if.merge.487 if.merge.487: ; preds = %if.else.486, %if.then.485 - %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -7910,12 +7919,12 @@ if.then.488: ; preds = %entry if.else.489: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 7 }, { ptr, i64 } %callN) br label %if.merge.490 if.merge.490: ; preds = %if.else.489, %if.then.488 - %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -7938,12 +7947,12 @@ if.then.491: ; preds = %entry if.else.492: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 8 }, { ptr, i64 } %callN) br label %if.merge.493 if.merge.493: ; preds = %if.else.492, %if.then.491 - %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -7966,12 +7975,12 @@ if.then.494: ; preds = %entry if.else.495: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 8 }, { ptr, i64 } %callN) br label %if.merge.496 if.merge.496: ; preds = %if.else.495, %if.then.494 - %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -7994,12 +8003,12 @@ if.then.497: ; preds = %entry if.else.498: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 12 }, { ptr, i64 } %callN) br label %if.merge.499 if.merge.499: ; preds = %if.else.498, %if.then.497 - %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -8022,12 +8031,12 @@ if.then.500: ; preds = %entry if.else.501: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 6 }, { ptr, i64 } %callN) br label %if.merge.502 if.merge.502: ; preds = %if.else.501, %if.then.500 - %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -8050,12 +8059,12 @@ if.then.503: ; preds = %entry if.else.504: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 8 }, { ptr, i64 } %callN) br label %if.merge.505 if.merge.505: ; preds = %if.else.504, %if.then.503 - %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -8078,12 +8087,12 @@ if.then.506: ; preds = %entry if.else.507: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 9 }, { ptr, i64 } %callN) br label %if.merge.508 if.merge.508: ; preds = %if.else.507, %if.then.506 - %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -8106,12 +8115,12 @@ if.then.509: ; preds = %entry if.else.510: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 18 }, { ptr, i64 } %callN) br label %if.merge.511 if.merge.511: ; preds = %if.else.510, %if.then.509 - %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -8134,12 +8143,12 @@ if.then.512: ; preds = %entry if.else.513: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 7 }, { ptr, i64 } %callN) br label %if.merge.514 if.merge.514: ; preds = %if.else.513, %if.then.512 - %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -8162,12 +8171,12 @@ if.then.515: ; preds = %entry if.else.516: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 4 }, { ptr, i64 } %callN) br label %if.merge.517 if.merge.517: ; preds = %if.else.516, %if.then.515 - %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.785, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -8190,12 +8199,12 @@ if.then.518: ; preds = %entry if.else.519: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 7 }, { ptr, i64 } %callN) br label %if.merge.520 if.merge.520: ; preds = %if.else.519, %if.then.518 - %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.788, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -8218,12 +8227,12 @@ if.then.521: ; preds = %entry if.else.522: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 6 }, { ptr, i64 } %callN) br label %if.merge.523 if.merge.523: ; preds = %if.else.522, %if.then.521 - %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.791, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -8246,12 +8255,12 @@ if.then.524: ; preds = %entry if.else.525: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 5 }, { ptr, i64 } %callN) br label %if.merge.526 if.merge.526: ; preds = %if.else.525, %if.then.524 - %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] + %bp = phi { ptr, i64 } [ { ptr @str.794, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] ret { ptr, i64 } %bp } @@ -8274,12 +8283,12 @@ if.then.527: ; preds = %entry if.else.528: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 11 }, { ptr, i64 } %callN) br label %if.merge.529 if.merge.529: ; preds = %if.else.528, %if.then.527 - %bp = phi { ptr, i64 } [ { ptr @str.795, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] + %bp = phi { ptr, i64 } [ { ptr @str.797, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] ret { ptr, i64 } %bp } @@ -8302,12 +8311,12 @@ if.then.530: ; preds = %entry if.else.531: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 9 }, { ptr, i64 } %callN) br label %if.merge.532 if.merge.532: ; preds = %if.else.531, %if.then.530 - %bp = phi { ptr, i64 } [ { ptr @str.798, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] + %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] ret { ptr, i64 } %bp } @@ -8330,12 +8339,12 @@ if.then.533: ; preds = %entry if.else.534: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 21 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 21 }, { ptr, i64 } %callN) br label %if.merge.535 if.merge.535: ; preds = %if.else.534, %if.then.533 - %bp = phi { ptr, i64 } [ { ptr @str.801, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] + %bp = phi { ptr, i64 } [ { ptr @str.803, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] ret { ptr, i64 } %bp } @@ -8351,7 +8360,7 @@ entry: br i1 %lnot, label %if.then.542, label %if.merge.543 if.then.542: ; preds = %entry - ret { ptr, i64 } { ptr @str.804, i64 4 } + ret { ptr, i64 } { ptr @str.806, i64 4 } if.merge.543: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8375,7 +8384,7 @@ entry: br i1 %lnot, label %if.then.544, label %if.merge.545 if.then.544: ; preds = %entry - ret { ptr, i64 } { ptr @str.805, i64 4 } + ret { ptr, i64 } { ptr @str.807, i64 4 } if.merge.545: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8399,7 +8408,7 @@ entry: br i1 %lnot, label %if.then.546, label %if.merge.547 if.then.546: ; preds = %entry - ret { ptr, i64 } { ptr @str.806, i64 4 } + ret { ptr, i64 } { ptr @str.808, i64 4 } if.merge.547: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8423,7 +8432,7 @@ entry: br i1 %lnot, label %if.then.548, label %if.merge.549 if.then.548: ; preds = %entry - ret { ptr, i64 } { ptr @str.807, i64 4 } + ret { ptr, i64 } { ptr @str.809, i64 4 } if.merge.549: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0414-protocols-generic-struct-protocol-erase.ir b/examples/expected/0414-protocols-generic-struct-protocol-erase.ir index b19fae4..bc64131 100644 --- a/examples/expected/0414-protocols-generic-struct-protocol-erase.ir +++ b/examples/expected/0414-protocols-generic-struct-protocol-erase.ir @@ -3,701 +3,701 @@ @__VL__s64__IntCell__vtable = internal constant { ptr } { ptr @__thunk_IntCell_VL__s64_get } @__VL__s64__Combined__s64__s64__vtable = internal constant { ptr } { ptr @__thunk_Combined__s64__s64_VL__s64_get } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [184 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [8 x i8] c"IntCell\00" -@tn.str.237 = private constant [9 x i8] c"*IntCell\00" -@tn.str.238 = private constant [2 x i8] c"R\00" -@tn.str.239 = private constant [9 x i8] c"Combined\00" -@tn.str.240 = private constant [8 x i8] c"VL__s64\00" -@tn.str.241 = private constant [18 x i8] c"__VL__s64__Vtable\00" -@tn.str.242 = private constant [3 x i8] c"VL\00" -@tn.str.243 = private constant [5 x i8] c"[]VL\00" -@tn.str.244 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.245 = private constant [7 x i8] c"**void\00" -@tn.str.246 = private constant [6 x i8] c"[]Any\00" -@tn.str.247 = private constant [5 x i8] c"*Any\00" -@tn.str.248 = private constant [7 x i8] c"[1]Any\00" -@tn.str.249 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.250 = private constant [7 x i8] c"*[]Any\00" -@tn.str.251 = private constant [10 x i8] c"(VL__s64)\00" -@tn.str.252 = private constant [19 x i8] c"Combined__s64__s64\00" -@tn.str.253 = private constant [20 x i8] c"*Combined__s64__s64\00" -@tn.str.254 = private constant [10 x i8] c"**IntCell\00" -@tn.str.255 = private constant [19 x i8] c"*__VL__s64__Vtable\00" -@tn.str.256 = private constant [11 x i8] c"*(VL__s64)\00" -@tn.str.257 = private constant [21 x i8] c"**Combined__s64__s64\00" -@tn.str.258 = private constant [9 x i8] c"*VL__s64\00" -@tn.str.259 = private constant [8 x i8] c"*string\00" -@tn.str.260 = private constant [6 x i8] c"*bool\00" -@tn.str.261 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.262 = private constant [5 x i8] c"*f64\00" -@tn.str.263 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.264 = private constant [11 x i8] c"*Allocator\00" -@tn.str.265 = private constant [9 x i8] c"*Context\00" -@tn.str.266 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.267 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.268 = private constant [8 x i8] c"*Member\00" -@tn.str.269 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.270 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.271 = private constant [9 x i8] c"*Command\00" -@tn.str.272 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.273 = private constant [3 x i8] c"*R\00" -@tn.str.274 = private constant [10 x i8] c"*Combined\00" -@tn.str.275 = private constant [4 x i8] c"*VL\00" -@tn.str.276 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.277 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.278 = private constant [7 x i8] c"*Value\00" -@tn.str.279 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.280 = private constant [14 x i8] c"*Architecture\00" -@tn.str.281 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.282 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.283 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.284 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.285 = private constant [10 x i8] c"*[]string\00" -@tn.str.286 = private constant [6 x i8] c"*[]u8\00" -@tn.str.287 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.288 = private constant [11 x i8] c"*[]Command\00" -@tn.str.289 = private constant [6 x i8] c"*[]VL\00" -@tn.str.290 = private constant [6 x i8] c"**GPA\00" -@tn.str.291 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.292 = private constant [8 x i8] c"**Arena\00" -@tn.str.293 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.294 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.295 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.296 = private constant [7 x i8] c"**File\00" -@tn.str.297 = private constant [5 x i8] c"**u8\00" -@tn.str.298 = private constant [6 x i8] c"**s32\00" -@tn.str.299 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.300 = private constant [6 x i8] c"**u32\00" -@tn.str.301 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.302 = private constant [8 x i8] c"**Array\00" -@tn.str.303 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.304 = private constant [9 x i8] c"**Object\00" -@tn.str.305 = private constant [7 x i8] c"**Sink\00" -@tn.str.306 = private constant [9 x i8] c"**Parser\00" -@tn.str.307 = private constant [6 x i8] c"**s64\00" -@tn.str.308 = private constant [9 x i8] c"**Parsed\00" -@tn.str.309 = private constant [7 x i8] c"**Diag\00" -@tn.str.310 = private constant [9 x i8] c"**Sha256\00" -@tn.str.311 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.312 = private constant [8 x i8] c"***void\00" -@tn.str.313 = private constant [6 x i8] c"**Any\00" -@tn.str.314 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.315 = private constant [8 x i8] c"**[]Any\00" -@tn.str.316 = private constant [11 x i8] c"***IntCell\00" -@tn.str.317 = private constant [20 x i8] c"**__VL__s64__Vtable\00" -@tn.str.318 = private constant [12 x i8] c"**(VL__s64)\00" -@tn.str.319 = private constant [22 x i8] c"***Combined__s64__s64\00" -@tn.str.320 = private constant [10 x i8] c"**VL__s64\00" -@tn.str.321 = private constant [9 x i8] c"**string\00" -@tn.str.322 = private constant [7 x i8] c"**bool\00" -@tn.str.323 = private constant [7 x i8] c"*?File\00" -@tn.str.324 = private constant [9 x i8] c"*?string\00" -@tn.str.325 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.326 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [184 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 8 }, { ptr, i64 } { ptr @tn.str.238, i64 1 }, { ptr, i64 } { ptr @tn.str.239, i64 8 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 17 }, { ptr, i64 } { ptr @tn.str.242, i64 2 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 12 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 4 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 9 }, { ptr, i64 } { ptr @tn.str.252, i64 18 }, { ptr, i64 } { ptr @tn.str.253, i64 19 }, { ptr, i64 } { ptr @tn.str.254, i64 9 }, { ptr, i64 } { ptr @tn.str.255, i64 18 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 20 }, { ptr, i64 } { ptr @tn.str.258, i64 8 }, { ptr, i64 } { ptr @tn.str.259, i64 7 }, { ptr, i64 } { ptr @tn.str.260, i64 5 }, { ptr, i64 } { ptr @tn.str.261, i64 7 }, { ptr, i64 } { ptr @tn.str.262, i64 4 }, { ptr, i64 } { ptr @tn.str.263, i64 16 }, { ptr, i64 } { ptr @tn.str.264, i64 10 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 11 }, { ptr, i64 } { ptr @tn.str.267, i64 14 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 13 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 10 }, { ptr, i64 } { ptr @tn.str.273, i64 2 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 3 }, { ptr, i64 } { ptr @tn.str.276, i64 9 }, { ptr, i64 } { ptr @tn.str.277, i64 9 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 16 }, { ptr, i64 } { ptr @tn.str.280, i64 13 }, { ptr, i64 } { ptr @tn.str.281, i64 14 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 7 }, { ptr, i64 } { ptr @tn.str.284, i64 8 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 11 }, { ptr, i64 } { ptr @tn.str.288, i64 10 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 12 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 19 }, { ptr, i64 } { ptr @tn.str.296, i64 6 }, { ptr, i64 } { ptr @tn.str.297, i64 4 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 10 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 9 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 10 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 5 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 6 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }, { ptr, i64 } { ptr @tn.str.311, i64 13 }, { ptr, i64 } { ptr @tn.str.312, i64 7 }, { ptr, i64 } { ptr @tn.str.313, i64 5 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { ptr, i64 } { ptr @tn.str.315, i64 7 }, { ptr, i64 } { ptr @tn.str.316, i64 10 }, { ptr, i64 } { ptr @tn.str.317, i64 19 }, { ptr, i64 } { ptr @tn.str.318, i64 11 }, { ptr, i64 } { ptr @tn.str.319, i64 21 }, { ptr, i64 } { ptr @tn.str.320, i64 9 }, { ptr, i64 } { ptr @tn.str.321, i64 8 }, { ptr, i64 } { ptr @tn.str.322, i64 6 }, { ptr, i64 } { ptr @tn.str.323, i64 6 }, { ptr, i64 } { ptr @tn.str.324, i64 8 }, { ptr, i64 } { ptr @tn.str.325, i64 15 }, { ptr, i64 } { ptr @tn.str.326, i64 8 }] -@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.328 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [8 x i8] c"IntCell\00" +@tn.str.239 = private constant [9 x i8] c"*IntCell\00" +@tn.str.240 = private constant [2 x i8] c"R\00" +@tn.str.241 = private constant [9 x i8] c"Combined\00" +@tn.str.242 = private constant [8 x i8] c"VL__s64\00" +@tn.str.243 = private constant [18 x i8] c"__VL__s64__Vtable\00" +@tn.str.244 = private constant [3 x i8] c"VL\00" +@tn.str.245 = private constant [5 x i8] c"[]VL\00" +@tn.str.246 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.247 = private constant [7 x i8] c"**void\00" +@tn.str.248 = private constant [6 x i8] c"[]Any\00" +@tn.str.249 = private constant [5 x i8] c"*Any\00" +@tn.str.250 = private constant [7 x i8] c"[1]Any\00" +@tn.str.251 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.252 = private constant [7 x i8] c"*[]Any\00" +@tn.str.253 = private constant [10 x i8] c"(VL__s64)\00" +@tn.str.254 = private constant [19 x i8] c"Combined__s64__s64\00" +@tn.str.255 = private constant [20 x i8] c"*Combined__s64__s64\00" +@tn.str.256 = private constant [10 x i8] c"**IntCell\00" +@tn.str.257 = private constant [19 x i8] c"*__VL__s64__Vtable\00" +@tn.str.258 = private constant [11 x i8] c"*(VL__s64)\00" +@tn.str.259 = private constant [21 x i8] c"**Combined__s64__s64\00" +@tn.str.260 = private constant [9 x i8] c"*VL__s64\00" +@tn.str.261 = private constant [8 x i8] c"*string\00" +@tn.str.262 = private constant [6 x i8] c"*bool\00" +@tn.str.263 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.264 = private constant [5 x i8] c"*f64\00" +@tn.str.265 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.266 = private constant [11 x i8] c"*Allocator\00" +@tn.str.267 = private constant [9 x i8] c"*Context\00" +@tn.str.268 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.269 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.270 = private constant [8 x i8] c"*Member\00" +@tn.str.271 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.272 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.273 = private constant [9 x i8] c"*Command\00" +@tn.str.274 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.275 = private constant [3 x i8] c"*R\00" +@tn.str.276 = private constant [10 x i8] c"*Combined\00" +@tn.str.277 = private constant [4 x i8] c"*VL\00" +@tn.str.278 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.279 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.280 = private constant [7 x i8] c"*Value\00" +@tn.str.281 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.282 = private constant [14 x i8] c"*Architecture\00" +@tn.str.283 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.284 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.285 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.286 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.287 = private constant [10 x i8] c"*[]string\00" +@tn.str.288 = private constant [6 x i8] c"*[]u8\00" +@tn.str.289 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.290 = private constant [11 x i8] c"*[]Command\00" +@tn.str.291 = private constant [6 x i8] c"*[]VL\00" +@tn.str.292 = private constant [6 x i8] c"**GPA\00" +@tn.str.293 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.294 = private constant [8 x i8] c"**Arena\00" +@tn.str.295 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.296 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.297 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.298 = private constant [7 x i8] c"**File\00" +@tn.str.299 = private constant [5 x i8] c"**u8\00" +@tn.str.300 = private constant [6 x i8] c"**s32\00" +@tn.str.301 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.302 = private constant [6 x i8] c"**u32\00" +@tn.str.303 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.304 = private constant [8 x i8] c"**Array\00" +@tn.str.305 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.306 = private constant [9 x i8] c"**Object\00" +@tn.str.307 = private constant [7 x i8] c"**Sink\00" +@tn.str.308 = private constant [9 x i8] c"**Parser\00" +@tn.str.309 = private constant [6 x i8] c"**s64\00" +@tn.str.310 = private constant [9 x i8] c"**Parsed\00" +@tn.str.311 = private constant [7 x i8] c"**Diag\00" +@tn.str.312 = private constant [9 x i8] c"**Sha256\00" +@tn.str.313 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.314 = private constant [8 x i8] c"***void\00" +@tn.str.315 = private constant [6 x i8] c"**Any\00" +@tn.str.316 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.317 = private constant [8 x i8] c"**[]Any\00" +@tn.str.318 = private constant [11 x i8] c"***IntCell\00" +@tn.str.319 = private constant [20 x i8] c"**__VL__s64__Vtable\00" +@tn.str.320 = private constant [12 x i8] c"**(VL__s64)\00" +@tn.str.321 = private constant [22 x i8] c"***Combined__s64__s64\00" +@tn.str.322 = private constant [10 x i8] c"**VL__s64\00" +@tn.str.323 = private constant [9 x i8] c"**string\00" +@tn.str.324 = private constant [7 x i8] c"**bool\00" +@tn.str.325 = private constant [7 x i8] c"*?File\00" +@tn.str.326 = private constant [9 x i8] c"*?string\00" +@tn.str.327 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.328 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [184 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 8 }, { ptr, i64 } { ptr @tn.str.240, i64 1 }, { ptr, i64 } { ptr @tn.str.241, i64 8 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 17 }, { ptr, i64 } { ptr @tn.str.244, i64 2 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 12 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 4 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 9 }, { ptr, i64 } { ptr @tn.str.254, i64 18 }, { ptr, i64 } { ptr @tn.str.255, i64 19 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 18 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 20 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 7 }, { ptr, i64 } { ptr @tn.str.262, i64 5 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 4 }, { ptr, i64 } { ptr @tn.str.265, i64 16 }, { ptr, i64 } { ptr @tn.str.266, i64 10 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 11 }, { ptr, i64 } { ptr @tn.str.269, i64 14 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 13 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 10 }, { ptr, i64 } { ptr @tn.str.275, i64 2 }, { ptr, i64 } { ptr @tn.str.276, i64 9 }, { ptr, i64 } { ptr @tn.str.277, i64 3 }, { ptr, i64 } { ptr @tn.str.278, i64 9 }, { ptr, i64 } { ptr @tn.str.279, i64 9 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 16 }, { ptr, i64 } { ptr @tn.str.282, i64 13 }, { ptr, i64 } { ptr @tn.str.283, i64 14 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 7 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 11 }, { ptr, i64 } { ptr @tn.str.290, i64 10 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 5 }, { ptr, i64 } { ptr @tn.str.293, i64 12 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 10 }, { ptr, i64 } { ptr @tn.str.297, i64 19 }, { ptr, i64 } { ptr @tn.str.298, i64 6 }, { ptr, i64 } { ptr @tn.str.299, i64 4 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 10 }, { ptr, i64 } { ptr @tn.str.302, i64 5 }, { ptr, i64 } { ptr @tn.str.303, i64 9 }, { ptr, i64 } { ptr @tn.str.304, i64 7 }, { ptr, i64 } { ptr @tn.str.305, i64 10 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 6 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 5 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }, { ptr, i64 } { ptr @tn.str.311, i64 6 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 13 }, { ptr, i64 } { ptr @tn.str.314, i64 7 }, { ptr, i64 } { ptr @tn.str.315, i64 5 }, { ptr, i64 } { ptr @tn.str.316, i64 8 }, { ptr, i64 } { ptr @tn.str.317, i64 7 }, { ptr, i64 } { ptr @tn.str.318, i64 10 }, { ptr, i64 } { ptr @tn.str.319, i64 19 }, { ptr, i64 } { ptr @tn.str.320, i64 11 }, { ptr, i64 } { ptr @tn.str.321, i64 21 }, { ptr, i64 } { ptr @tn.str.322, i64 9 }, { ptr, i64 } { ptr @tn.str.323, i64 8 }, { ptr, i64 } { ptr @tn.str.324, i64 6 }, { ptr, i64 } { ptr @tn.str.325, i64 6 }, { ptr, i64 } { ptr @tn.str.326, i64 8 }, { ptr, i64 } { ptr @tn.str.327, i64 15 }, { ptr, i64 } { ptr @tn.str.328, i64 8 }] @str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.331 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.333 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.334 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.335 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.336 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.337 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.338 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.339 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.341 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.342 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.343 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.344 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.345 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.347 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.348 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.349 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.333 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.335 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.336 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.337 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.338 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.339 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.340 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.341 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.342 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.343 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.344 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.345 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.346 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.347 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.348 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.349 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.350 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.351 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.351 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.352 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.353 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.354 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.356 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.355 = private constant [5 x i8] c"line\00" -@fld.str.356 = private constant [4 x i8] c"col\00" -@fld.str.357 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.355, i64 4 }, { ptr, i64 } { ptr @fld.str.356, i64 3 }, { ptr, i64 } { ptr @fld.str.357, i64 4 }] -@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.359 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.361 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.363 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.365 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.367 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.369 = private constant [12 x i8] c"alloc_count\00" -@field_names.370 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.369, i64 11 }] -@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.372 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.374 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.375 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.376 = private constant [5 x i8] c"next\00" -@fld.str.377 = private constant [4 x i8] c"cap\00" -@field_names.378 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.376, i64 4 }, { ptr, i64 } { ptr @fld.str.377, i64 3 }] -@str.379 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.380 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.381 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.382 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.383 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.384 = private constant [4 x i8] c"ctx\00" -@fld.str.385 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.386 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.387 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.384, i64 3 }, { ptr, i64 } { ptr @fld.str.385, i64 11 }, { ptr, i64 } { ptr @fld.str.386, i64 13 }] -@str.388 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.389 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.390 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.391 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.392 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.393 = private constant [6 x i8] c"first\00" -@fld.str.394 = private constant [10 x i8] c"end_index\00" -@fld.str.395 = private constant [7 x i8] c"parent\00" -@field_names.396 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.393, i64 5 }, { ptr, i64 } { ptr @fld.str.394, i64 9 }, { ptr, i64 } { ptr @fld.str.395, i64 6 }] -@str.397 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.398 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.399 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.400 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.401 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.402 = private constant [4 x i8] c"buf\00" -@fld.str.403 = private constant [4 x i8] c"len\00" -@fld.str.404 = private constant [4 x i8] c"pos\00" -@field_names.405 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.402, i64 3 }, { ptr, i64 } { ptr @fld.str.403, i64 3 }, { ptr, i64 } { ptr @fld.str.404, i64 3 }] -@str.406 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.407 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.408 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.409 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.410 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.411 = private constant [7 x i8] c"parent\00" -@fld.str.412 = private constant [12 x i8] c"alloc_count\00" -@fld.str.413 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.414 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.415 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.411, i64 6 }, { ptr, i64 } { ptr @fld.str.412, i64 11 }, { ptr, i64 } { ptr @fld.str.413, i64 13 }, { ptr, i64 } { ptr @fld.str.414, i64 17 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [10 x i8] c"allocator\00" -@fld.str.422 = private constant [5 x i8] c"data\00" -@field_names.423 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 9 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }] -@str.424 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.425 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.426 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.427 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.428 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.429 = private constant [3 x i8] c"fd\00" -@field_names.430 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.429, i64 2 }] -@str.431 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.432 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.433 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.434 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.435 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.436 = private constant [5 x i8] c"file\00" -@fld.str.437 = private constant [5 x i8] c"line\00" -@fld.str.438 = private constant [4 x i8] c"col\00" -@fld.str.439 = private constant [5 x i8] c"func\00" -@fld.str.440 = private constant [10 x i8] c"line_text\00" -@field_names.441 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.436, i64 4 }, { ptr, i64 } { ptr @fld.str.437, i64 4 }, { ptr, i64 } { ptr @fld.str.438, i64 3 }, { ptr, i64 } { ptr @fld.str.439, i64 4 }, { ptr, i64 } { ptr @fld.str.440, i64 9 }] -@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.443 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.447 = private constant [10 x i8] c"exit_code\00" -@fld.str.448 = private constant [7 x i8] c"stdout\00" -@field_names.449 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 9 }, { ptr, i64 } { ptr @fld.str.448, i64 6 }] -@str.450 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.451 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.452 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.453 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.454 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.455 = private constant [8 x i8] c"sin_len\00" -@fld.str.456 = private constant [11 x i8] c"sin_family\00" -@fld.str.457 = private constant [9 x i8] c"sin_port\00" -@fld.str.458 = private constant [9 x i8] c"sin_addr\00" -@fld.str.459 = private constant [9 x i8] c"sin_zero\00" -@field_names.460 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.455, i64 7 }, { ptr, i64 } { ptr @fld.str.456, i64 10 }, { ptr, i64 } { ptr @fld.str.457, i64 8 }, { ptr, i64 } { ptr @fld.str.458, i64 8 }, { ptr, i64 } { ptr @fld.str.459, i64 8 }] -@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.462 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.463 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.465 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.466 = private constant [6 x i8] c"items\00" -@fld.str.467 = private constant [4 x i8] c"len\00" -@fld.str.468 = private constant [4 x i8] c"cap\00" -@field_names.469 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.466, i64 5 }, { ptr, i64 } { ptr @fld.str.467, i64 3 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }] -@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.471 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.475 = private constant [6 x i8] c"items\00" -@fld.str.476 = private constant [4 x i8] c"len\00" -@fld.str.477 = private constant [4 x i8] c"cap\00" -@field_names.478 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 5 }, { ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [4 x i8] c"key\00" -@fld.str.485 = private constant [4 x i8] c"val\00" -@field_names.486 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }] -@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.488 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.489 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.490 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.491 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.492 = private constant [4 x i8] c"dst\00" -@fld.str.493 = private constant [4 x i8] c"pos\00" -@fld.str.494 = private constant [5 x i8] c"file\00" -@field_names.495 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.492, i64 3 }, { ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 4 }] -@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.497 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.501 = private constant [4 x i8] c"src\00" -@fld.str.502 = private constant [4 x i8] c"pos\00" -@fld.str.503 = private constant [6 x i8] c"alloc\00" -@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 3 }, { ptr, i64 } { ptr @fld.str.502, i64 3 }, { ptr, i64 } { ptr @fld.str.503, i64 5 }] -@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.506 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.510 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.512 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.513 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.514 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.515 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.516 = private constant [5 x i8] c"name\00" -@fld.str.517 = private constant [12 x i8] c"takes_value\00" -@fld.str.518 = private constant [9 x i8] c"required\00" -@field_names.519 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 4 }, { ptr, i64 } { ptr @fld.str.517, i64 11 }, { ptr, i64 } { ptr @fld.str.518, i64 8 }] -@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.521 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.522 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.523 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.524 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.525 = private constant [6 x i8] c"group\00" -@fld.str.526 = private constant [8 x i8] c"command\00" -@fld.str.527 = private constant [6 x i8] c"flags\00" -@field_names.528 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 5 }, { ptr, i64 } { ptr @fld.str.526, i64 7 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] -@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.530 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.534 = private constant [4 x i8] c"set\00" -@fld.str.535 = private constant [6 x i8] c"value\00" -@field_names.536 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 3 }, { ptr, i64 } { ptr @fld.str.535, i64 5 }] -@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.538 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.542 = private constant [6 x i8] c"index\00" -@fld.str.543 = private constant [6 x i8] c"token\00" -@field_names.544 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 5 }, { ptr, i64 } { ptr @fld.str.543, i64 5 }] -@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.546 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.550 = private constant [6 x i8] c"group\00" -@fld.str.551 = private constant [8 x i8] c"command\00" -@fld.str.552 = private constant [10 x i8] c"cmd_index\00" -@fld.str.553 = private constant [5 x i8] c"json\00" -@fld.str.554 = private constant [5 x i8] c"rest\00" -@fld.str.555 = private constant [5 x i8] c"spec\00" -@fld.str.556 = private constant [7 x i8] c"values\00" -@field_names.557 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 5 }, { ptr, i64 } { ptr @fld.str.551, i64 7 }, { ptr, i64 } { ptr @fld.str.552, i64 9 }, { ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 4 }, { ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 6 }] -@str.558 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.559 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.562 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.563 = private constant [2 x i8] c"h\00" -@fld.str.564 = private constant [4 x i8] c"buf\00" -@fld.str.565 = private constant [8 x i8] c"buf_len\00" -@fld.str.566 = private constant [10 x i8] c"total_len\00" -@field_names.567 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 1 }, { ptr, i64 } { ptr @fld.str.564, i64 3 }, { ptr, i64 } { ptr @fld.str.565, i64 7 }, { ptr, i64 } { ptr @fld.str.566, i64 9 }] -@str.568 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.569 = private unnamed_addr constant [8 x i8] c"IntCell\00", align 1 -@str.570 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.571 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.572 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.573 = private constant [2 x i8] c"v\00" -@field_names.574 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 1 }] -@str.575 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c"R\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.579 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.580 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.581 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.582 = private unnamed_addr constant [9 x i8] c"Combined\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.585 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.586 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.587 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.588 = private unnamed_addr constant [8 x i8] c"VL__s64\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.591 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.592 = private constant [4 x i8] c"ctx\00" -@fld.str.593 = private constant [9 x i8] c"__vtable\00" -@field_names.594 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.592, i64 3 }, { ptr, i64 } { ptr @fld.str.593, i64 8 }] -@str.595 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.596 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.599 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.600 = private constant [4 x i8] c"get\00" -@field_names.601 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.600, i64 3 }] -@str.602 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.603 = private unnamed_addr constant [3 x i8] c"VL\00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.607 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.608 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.609 = private unnamed_addr constant [19 x i8] c"Combined__s64__s64\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.613 = private constant [8 x i8] c"sources\00" -@fld.str.614 = private constant [6 x i8] c"value\00" -@field_names.615 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.613, i64 7 }, { ptr, i64 } { ptr @fld.str.614, i64 5 }] -@str.616 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.618 = private constant [5 x i8] c"read\00" -@fld.str.619 = private constant [6 x i8] c"write\00" -@fld.str.620 = private constant [7 x i8] c"append\00" -@fld.str.621 = private constant [11 x i8] c"read_write\00" -@field_names.622 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.618, i64 4 }, { ptr, i64 } { ptr @fld.str.619, i64 5 }, { ptr, i64 } { ptr @fld.str.620, i64 6 }, { ptr, i64 } { ptr @fld.str.621, i64 10 }] -@str.623 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.626 = private constant [4 x i8] c"set\00" -@fld.str.627 = private constant [8 x i8] c"current\00" -@fld.str.628 = private constant [4 x i8] c"end\00" -@field_names.629 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.626, i64 3 }, { ptr, i64 } { ptr @fld.str.627, i64 7 }, { ptr, i64 } { ptr @fld.str.628, i64 3 }] -@str.630 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.633 = private constant [6 x i8] c"null_\00" -@fld.str.634 = private constant [6 x i8] c"bool_\00" -@fld.str.635 = private constant [5 x i8] c"int_\00" -@fld.str.636 = private constant [4 x i8] c"str\00" -@fld.str.637 = private constant [6 x i8] c"array\00" -@fld.str.638 = private constant [7 x i8] c"object\00" -@field_names.639 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.633, i64 5 }, { ptr, i64 } { ptr @fld.str.634, i64 5 }, { ptr, i64 } { ptr @fld.str.635, i64 4 }, { ptr, i64 } { ptr @fld.str.636, i64 3 }, { ptr, i64 } { ptr @fld.str.637, i64 5 }, { ptr, i64 } { ptr @fld.str.638, i64 6 }] -@str.640 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.641 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.642 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.643 = private constant [6 x i8] c"macos\00" -@fld.str.644 = private constant [6 x i8] c"linux\00" -@fld.str.645 = private constant [8 x i8] c"windows\00" -@fld.str.646 = private constant [5 x i8] c"wasm\00" -@fld.str.647 = private constant [4 x i8] c"ios\00" -@fld.str.648 = private constant [8 x i8] c"android\00" -@fld.str.649 = private constant [8 x i8] c"unknown\00" -@field_names.650 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.643, i64 5 }, { ptr, i64 } { ptr @fld.str.644, i64 5 }, { ptr, i64 } { ptr @fld.str.645, i64 7 }, { ptr, i64 } { ptr @fld.str.646, i64 4 }, { ptr, i64 } { ptr @fld.str.647, i64 3 }, { ptr, i64 } { ptr @fld.str.648, i64 7 }, { ptr, i64 } { ptr @fld.str.649, i64 7 }] -@str.651 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.652 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.653 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.654 = private constant [8 x i8] c"aarch64\00" -@fld.str.655 = private constant [7 x i8] c"x86_64\00" -@fld.str.656 = private constant [7 x i8] c"wasm32\00" -@fld.str.657 = private constant [7 x i8] c"wasm64\00" -@fld.str.658 = private constant [8 x i8] c"unknown\00" -@field_names.659 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.654, i64 7 }, { ptr, i64 } { ptr @fld.str.655, i64 6 }, { ptr, i64 } { ptr @fld.str.656, i64 6 }, { ptr, i64 } { ptr @fld.str.657, i64 6 }, { ptr, i64 } { ptr @fld.str.658, i64 7 }] -@str.660 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.661 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.662 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.663 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.664 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.665 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.668 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.669 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.670 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.671 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.672 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.673 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.674 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.677 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.678 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.679 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.680 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.681 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.682 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.683 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.684 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.685 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.686 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.687 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.688 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.689 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.690 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.691 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.692 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.693 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.694 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.695 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.696 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.723 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.726 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.732 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.735 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.738 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.741 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.742 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.744 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.745 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.747 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.750 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.753 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.756 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.759 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.762 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.765 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.768 = private unnamed_addr constant [9 x i8] c"*IntCell\00", align 1 -@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.771 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.774 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.777 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.780 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.783 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.786 = private unnamed_addr constant [20 x i8] c"*Combined__s64__s64\00", align 1 -@str.787 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.789 = private unnamed_addr constant [10 x i8] c"**IntCell\00", align 1 -@str.790 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.791 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.792 = private unnamed_addr constant [19 x i8] c"*__VL__s64__Vtable\00", align 1 -@str.793 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.795 = private unnamed_addr constant [7 x i8] c"*tuple\00", align 1 -@str.796 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.798 = private unnamed_addr constant [21 x i8] c"**Combined__s64__s64\00", align 1 -@str.799 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.800 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.801 = private unnamed_addr constant [9 x i8] c"*VL__s64\00", align 1 -@str.802 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.803 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.804 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.805 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.806 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.807 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.808 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.809 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.810 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.357 = private constant [5 x i8] c"line\00" +@fld.str.358 = private constant [4 x i8] c"col\00" +@fld.str.359 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.357, i64 4 }, { ptr, i64 } { ptr @fld.str.358, i64 3 }, { ptr, i64 } { ptr @fld.str.359, i64 4 }] +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [4 x i8] c"ctx\00" +@fld.str.366 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.367 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.368 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 3 }, { ptr, i64 } { ptr @fld.str.366, i64 11 }, { ptr, i64 } { ptr @fld.str.367, i64 13 }] +@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.370 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.372 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.374 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.376 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.380 = private constant [12 x i8] c"alloc_count\00" +@field_names.381 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 11 }] +@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.383 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.387 = private constant [5 x i8] c"next\00" +@fld.str.388 = private constant [4 x i8] c"cap\00" +@field_names.389 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 4 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }] +@str.390 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.391 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.393 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.394 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.395 = private constant [6 x i8] c"first\00" +@fld.str.396 = private constant [10 x i8] c"end_index\00" +@fld.str.397 = private constant [7 x i8] c"parent\00" +@field_names.398 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.395, i64 5 }, { ptr, i64 } { ptr @fld.str.396, i64 9 }, { ptr, i64 } { ptr @fld.str.397, i64 6 }] +@str.399 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.400 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.401 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.402 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.403 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.404 = private constant [4 x i8] c"buf\00" +@fld.str.405 = private constant [4 x i8] c"len\00" +@fld.str.406 = private constant [4 x i8] c"pos\00" +@field_names.407 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.404, i64 3 }, { ptr, i64 } { ptr @fld.str.405, i64 3 }, { ptr, i64 } { ptr @fld.str.406, i64 3 }] +@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.409 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.413 = private constant [7 x i8] c"parent\00" +@fld.str.414 = private constant [12 x i8] c"alloc_count\00" +@fld.str.415 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.416 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.417 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 6 }, { ptr, i64 } { ptr @fld.str.414, i64 11 }, { ptr, i64 } { ptr @fld.str.415, i64 13 }, { ptr, i64 } { ptr @fld.str.416, i64 17 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [10 x i8] c"allocator\00" +@fld.str.424 = private constant [5 x i8] c"data\00" +@field_names.425 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 9 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }] +@str.426 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.427 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.428 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.429 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.430 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.431 = private constant [3 x i8] c"fd\00" +@field_names.432 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.431, i64 2 }] +@str.433 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.434 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.435 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.436 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.437 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.438 = private constant [5 x i8] c"file\00" +@fld.str.439 = private constant [5 x i8] c"line\00" +@fld.str.440 = private constant [4 x i8] c"col\00" +@fld.str.441 = private constant [5 x i8] c"func\00" +@fld.str.442 = private constant [10 x i8] c"line_text\00" +@field_names.443 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.438, i64 4 }, { ptr, i64 } { ptr @fld.str.439, i64 4 }, { ptr, i64 } { ptr @fld.str.440, i64 3 }, { ptr, i64 } { ptr @fld.str.441, i64 4 }, { ptr, i64 } { ptr @fld.str.442, i64 9 }] +@str.444 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.445 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.446 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.447 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.448 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.449 = private constant [10 x i8] c"exit_code\00" +@fld.str.450 = private constant [7 x i8] c"stdout\00" +@field_names.451 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.449, i64 9 }, { ptr, i64 } { ptr @fld.str.450, i64 6 }] +@str.452 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.453 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.454 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.455 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.456 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.457 = private constant [8 x i8] c"sin_len\00" +@fld.str.458 = private constant [11 x i8] c"sin_family\00" +@fld.str.459 = private constant [9 x i8] c"sin_port\00" +@fld.str.460 = private constant [9 x i8] c"sin_addr\00" +@fld.str.461 = private constant [9 x i8] c"sin_zero\00" +@field_names.462 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.457, i64 7 }, { ptr, i64 } { ptr @fld.str.458, i64 10 }, { ptr, i64 } { ptr @fld.str.459, i64 8 }, { ptr, i64 } { ptr @fld.str.460, i64 8 }, { ptr, i64 } { ptr @fld.str.461, i64 8 }] +@str.463 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.464 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.465 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.467 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.468 = private constant [6 x i8] c"items\00" +@fld.str.469 = private constant [4 x i8] c"len\00" +@fld.str.470 = private constant [4 x i8] c"cap\00" +@field_names.471 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.468, i64 5 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }] +@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.473 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.477 = private constant [6 x i8] c"items\00" +@fld.str.478 = private constant [4 x i8] c"len\00" +@fld.str.479 = private constant [4 x i8] c"cap\00" +@field_names.480 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 5 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [4 x i8] c"key\00" +@fld.str.487 = private constant [4 x i8] c"val\00" +@field_names.488 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }] +@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.490 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.494 = private constant [4 x i8] c"dst\00" +@fld.str.495 = private constant [4 x i8] c"pos\00" +@fld.str.496 = private constant [5 x i8] c"file\00" +@field_names.497 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.494, i64 3 }, { ptr, i64 } { ptr @fld.str.495, i64 3 }, { ptr, i64 } { ptr @fld.str.496, i64 4 }] +@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.499 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.503 = private constant [4 x i8] c"src\00" +@fld.str.504 = private constant [4 x i8] c"pos\00" +@fld.str.505 = private constant [6 x i8] c"alloc\00" +@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 3 }, { ptr, i64 } { ptr @fld.str.504, i64 3 }, { ptr, i64 } { ptr @fld.str.505, i64 5 }] +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.512 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.513 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.514 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.515 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.516 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.517 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.518 = private constant [5 x i8] c"name\00" +@fld.str.519 = private constant [12 x i8] c"takes_value\00" +@fld.str.520 = private constant [9 x i8] c"required\00" +@field_names.521 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.518, i64 4 }, { ptr, i64 } { ptr @fld.str.519, i64 11 }, { ptr, i64 } { ptr @fld.str.520, i64 8 }] +@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.523 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.524 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.525 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.526 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.527 = private constant [6 x i8] c"group\00" +@fld.str.528 = private constant [8 x i8] c"command\00" +@fld.str.529 = private constant [6 x i8] c"flags\00" +@field_names.530 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 5 }, { ptr, i64 } { ptr @fld.str.528, i64 7 }, { ptr, i64 } { ptr @fld.str.529, i64 5 }] +@str.531 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.532 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.535 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.536 = private constant [4 x i8] c"set\00" +@fld.str.537 = private constant [6 x i8] c"value\00" +@field_names.538 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.536, i64 3 }, { ptr, i64 } { ptr @fld.str.537, i64 5 }] +@str.539 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.540 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.542 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.543 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.544 = private constant [6 x i8] c"index\00" +@fld.str.545 = private constant [6 x i8] c"token\00" +@field_names.546 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.544, i64 5 }, { ptr, i64 } { ptr @fld.str.545, i64 5 }] +@str.547 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.548 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.550 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.551 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.552 = private constant [6 x i8] c"group\00" +@fld.str.553 = private constant [8 x i8] c"command\00" +@fld.str.554 = private constant [10 x i8] c"cmd_index\00" +@fld.str.555 = private constant [5 x i8] c"json\00" +@fld.str.556 = private constant [5 x i8] c"rest\00" +@fld.str.557 = private constant [5 x i8] c"spec\00" +@fld.str.558 = private constant [7 x i8] c"values\00" +@field_names.559 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.552, i64 5 }, { ptr, i64 } { ptr @fld.str.553, i64 7 }, { ptr, i64 } { ptr @fld.str.554, i64 9 }, { ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 4 }, { ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 6 }] +@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.561 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.564 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.565 = private constant [2 x i8] c"h\00" +@fld.str.566 = private constant [4 x i8] c"buf\00" +@fld.str.567 = private constant [8 x i8] c"buf_len\00" +@fld.str.568 = private constant [10 x i8] c"total_len\00" +@field_names.569 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 1 }, { ptr, i64 } { ptr @fld.str.566, i64 3 }, { ptr, i64 } { ptr @fld.str.567, i64 7 }, { ptr, i64 } { ptr @fld.str.568, i64 9 }] +@str.570 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.571 = private unnamed_addr constant [8 x i8] c"IntCell\00", align 1 +@str.572 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.573 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.574 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.575 = private constant [2 x i8] c"v\00" +@field_names.576 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 1 }] +@str.577 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c"R\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.581 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.582 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.583 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.584 = private unnamed_addr constant [9 x i8] c"Combined\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.587 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.588 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.589 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.590 = private unnamed_addr constant [8 x i8] c"VL__s64\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.593 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.594 = private constant [4 x i8] c"ctx\00" +@fld.str.595 = private constant [9 x i8] c"__vtable\00" +@field_names.596 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.594, i64 3 }, { ptr, i64 } { ptr @fld.str.595, i64 8 }] +@str.597 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.598 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.602 = private constant [4 x i8] c"get\00" +@field_names.603 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 3 }] +@str.604 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.605 = private unnamed_addr constant [3 x i8] c"VL\00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.609 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.610 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.611 = private unnamed_addr constant [19 x i8] c"Combined__s64__s64\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.615 = private constant [8 x i8] c"sources\00" +@fld.str.616 = private constant [6 x i8] c"value\00" +@field_names.617 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.615, i64 7 }, { ptr, i64 } { ptr @fld.str.616, i64 5 }] +@str.618 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.620 = private constant [5 x i8] c"read\00" +@fld.str.621 = private constant [6 x i8] c"write\00" +@fld.str.622 = private constant [7 x i8] c"append\00" +@fld.str.623 = private constant [11 x i8] c"read_write\00" +@field_names.624 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.620, i64 4 }, { ptr, i64 } { ptr @fld.str.621, i64 5 }, { ptr, i64 } { ptr @fld.str.622, i64 6 }, { ptr, i64 } { ptr @fld.str.623, i64 10 }] +@str.625 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.628 = private constant [4 x i8] c"set\00" +@fld.str.629 = private constant [8 x i8] c"current\00" +@fld.str.630 = private constant [4 x i8] c"end\00" +@field_names.631 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.628, i64 3 }, { ptr, i64 } { ptr @fld.str.629, i64 7 }, { ptr, i64 } { ptr @fld.str.630, i64 3 }] +@str.632 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.635 = private constant [6 x i8] c"null_\00" +@fld.str.636 = private constant [6 x i8] c"bool_\00" +@fld.str.637 = private constant [5 x i8] c"int_\00" +@fld.str.638 = private constant [4 x i8] c"str\00" +@fld.str.639 = private constant [6 x i8] c"array\00" +@fld.str.640 = private constant [7 x i8] c"object\00" +@field_names.641 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.635, i64 5 }, { ptr, i64 } { ptr @fld.str.636, i64 5 }, { ptr, i64 } { ptr @fld.str.637, i64 4 }, { ptr, i64 } { ptr @fld.str.638, i64 3 }, { ptr, i64 } { ptr @fld.str.639, i64 5 }, { ptr, i64 } { ptr @fld.str.640, i64 6 }] +@str.642 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.643 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.644 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.645 = private constant [6 x i8] c"macos\00" +@fld.str.646 = private constant [6 x i8] c"linux\00" +@fld.str.647 = private constant [8 x i8] c"windows\00" +@fld.str.648 = private constant [5 x i8] c"wasm\00" +@fld.str.649 = private constant [4 x i8] c"ios\00" +@fld.str.650 = private constant [8 x i8] c"android\00" +@fld.str.651 = private constant [8 x i8] c"unknown\00" +@field_names.652 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.645, i64 5 }, { ptr, i64 } { ptr @fld.str.646, i64 5 }, { ptr, i64 } { ptr @fld.str.647, i64 7 }, { ptr, i64 } { ptr @fld.str.648, i64 4 }, { ptr, i64 } { ptr @fld.str.649, i64 3 }, { ptr, i64 } { ptr @fld.str.650, i64 7 }, { ptr, i64 } { ptr @fld.str.651, i64 7 }] +@str.653 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.654 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.655 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.656 = private constant [8 x i8] c"aarch64\00" +@fld.str.657 = private constant [7 x i8] c"x86_64\00" +@fld.str.658 = private constant [7 x i8] c"wasm32\00" +@fld.str.659 = private constant [7 x i8] c"wasm64\00" +@fld.str.660 = private constant [8 x i8] c"unknown\00" +@field_names.661 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.656, i64 7 }, { ptr, i64 } { ptr @fld.str.657, i64 6 }, { ptr, i64 } { ptr @fld.str.658, i64 6 }, { ptr, i64 } { ptr @fld.str.659, i64 6 }, { ptr, i64 } { ptr @fld.str.660, i64 7 }] +@str.662 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.663 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.664 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.665 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.666 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.667 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.669 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.670 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.671 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.672 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.673 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.674 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.675 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.676 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.678 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.679 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.680 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.681 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.682 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.683 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.684 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.685 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.686 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.687 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.688 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.689 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.690 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.691 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.692 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.693 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.694 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.695 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.696 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.697 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.698 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.699 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.728 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.729 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.732 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.734 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.735 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.738 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.740 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.741 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.742 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.743 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.744 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.745 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.746 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.747 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.748 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.749 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.750 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.751 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.752 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.753 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.754 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.755 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.756 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.757 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.758 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.759 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.760 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.761 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.762 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.763 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.764 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.765 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.766 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.767 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.768 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.769 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.770 = private unnamed_addr constant [9 x i8] c"*IntCell\00", align 1 +@str.771 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.772 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.773 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.774 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.775 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.776 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.777 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.778 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.779 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.780 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.781 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.782 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.783 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.784 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.785 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.786 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.787 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.788 = private unnamed_addr constant [20 x i8] c"*Combined__s64__s64\00", align 1 +@str.789 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.790 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.791 = private unnamed_addr constant [10 x i8] c"**IntCell\00", align 1 +@str.792 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.793 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.794 = private unnamed_addr constant [19 x i8] c"*__VL__s64__Vtable\00", align 1 +@str.795 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.796 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.797 = private unnamed_addr constant [7 x i8] c"*tuple\00", align 1 +@str.798 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.799 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.800 = private unnamed_addr constant [21 x i8] c"**Combined__s64__s64\00", align 1 +@str.801 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.802 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.803 = private unnamed_addr constant [9 x i8] c"*VL__s64\00", align 1 +@str.804 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.805 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.806 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.807 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.808 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.809 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.810 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.811 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.812 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.813 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.814 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -710,6 +710,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -929,7 +932,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1056,7 +1059,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1390,7 +1393,7 @@ entry: br i1 %icmp, label %if.then.423, label %if.merge.424 if.then.423: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.424: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1540,7 +1543,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1566,9 +1569,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1617,9 +1620,9 @@ entry: i64 100, label %match.arm.48 i64 103, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1665,7 +1668,7 @@ match.merge.37: ; preds = %dispatch.merge.544, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1709,9 +1712,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1800,9 +1803,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.382 [ i64 18, label %dispatch.case.383 - i64 21, label %dispatch.case.384 - i64 23, label %dispatch.case.385 - i64 25, label %dispatch.case.386 + i64 22, label %dispatch.case.384 + i64 24, label %dispatch.case.385 + i64 26, label %dispatch.case.386 i64 28, label %dispatch.case.387 i64 29, label %dispatch.case.388 i64 31, label %dispatch.case.389 @@ -1906,7 +1909,7 @@ dispatch.merge.94: ; preds = %dispatch.case.127, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1920,32 +1923,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2171,7 +2174,7 @@ dispatch.merge.288: ; preds = %dispatch.case.294, br label %match.merge.37 dispatch.default.289: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.288 dispatch.case.290: ; preds = %match.arm.44 @@ -2212,7 +2215,7 @@ dispatch.merge.305: ; preds = %dispatch.case.312, br label %match.merge.37 dispatch.default.306: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.305 dispatch.case.307: ; preds = %match.arm.47 @@ -2269,7 +2272,7 @@ dispatch.merge.343: ; preds = %dispatch.case.350, br label %match.merge.37 dispatch.default.344: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.343 dispatch.case.345: ; preds = %match.arm.48 @@ -2326,7 +2329,7 @@ dispatch.merge.381: ; preds = %dispatch.case.419, br label %match.merge.37 dispatch.default.382: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.331, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.381 dispatch.case.383: ; preds = %match.arm.49 @@ -2594,7 +2597,7 @@ dispatch.merge.544: ; preds = %dispatch.case.549, br label %match.merge.37 dispatch.default.545: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.544 dispatch.case.546: ; preds = %match.arm.50 @@ -2636,7 +2639,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2732,7 +2735,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2740,7 +2743,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2750,13 +2753,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2764,7 +2767,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2778,7 +2781,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2786,7 +2789,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2797,7 +2800,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2854,7 +2857,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2862,7 +2865,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2873,7 +2876,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2893,7 +2896,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2901,7 +2904,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, 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 @@ -2912,7 +2915,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2922,64 +2925,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3155,163 +3161,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3509,64 +3518,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3596,97 +3605,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3725,7 +3734,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @IntCell.get(ptr %0, ptr %1) #0 { @@ -3835,7 +3844,7 @@ entry: define internal void @print__ct_sbc6305862a3a863d__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.348, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.350, i64 3 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3850,7 +3859,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.349, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.351, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -3872,7 +3881,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.350, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.352, i64 3 }) ret { ptr, i64 } %call } @@ -3883,7 +3892,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 15 }, { ptr, i64 } { ptr @str.352, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.353, i64 15 }, { ptr, i64 } { ptr @str.354, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3902,12 +3911,12 @@ while.body.129: ; preds = %while.hdr.128 while.exit.130: ; preds = %while.hdr.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 1 }) ret { ptr, i64 } %callN if.then.131: ; preds = %while.body.129 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.132 @@ -3919,7 +3928,7 @@ if.merge.132: ; preds = %if.then.131, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3972,20 +3981,20 @@ fv.case24: ; preds = %if.merge.132 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.359, i64 10 }, { ptr, i64 } { ptr @str.360, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 9 }, { ptr, i64 } { ptr @str.362, 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.133 -while.hdr.133: ; preds = %if.merge.137, %entry +while.hdr.133: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.134, label %while.exit.135 while.body.134: ; preds = %while.hdr.133 @@ -3995,224 +4004,24 @@ while.body.134: ; preds = %while.hdr.133 while.exit.135: ; preds = %while.hdr.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) ret { ptr, i64 } %callN if.then.136: ; preds = %while.body.134 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.137 if.merge.137: ; preds = %if.then.136, %while.body.134 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.363, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.368, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.133 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.365, i64 3 }, { ptr, i64 } { ptr @str.366, 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.138 - -while.hdr.138: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.139, label %while.exit.140 - -while.body.139: ; preds = %while.hdr.138 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.141, label %if.merge.142 - -while.exit.140: ; preds = %while.hdr.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 1 }) - ret { ptr, i64 } %callN - -if.then.141: ; preds = %while.body.139 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.142 - -if.merge.142: ; preds = %if.then.141, %while.body.139 - %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.370, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.138 - -fv.default: ; preds = %if.merge.142 - br label %fv.merge - -fv.case: ; preds = %if.merge.142 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.372, i64 10 }, { ptr, i64 } { ptr @str.373, 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.143 - -while.hdr.143: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.144, label %while.exit.145 - -while.body.144: ; preds = %while.hdr.143 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.146, label %if.merge.147 - -while.exit.145: ; preds = %while.hdr.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 1 }) - ret { ptr, i64 } %callN - -if.then.146: ; preds = %while.body.144 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.147 - -if.merge.147: ; preds = %if.then.146, %while.body.144 - %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.378, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.143 - -fv.default: ; preds = %if.merge.147 - br label %fv.merge - -fv.case: ; preds = %if.merge.147 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.147 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.380, i64 9 }, { ptr, i64 } { ptr @str.381, 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.148 - -while.hdr.148: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.149, label %while.exit.150 - -while.body.149: ; preds = %while.hdr.148 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.151, label %if.merge.152 - -while.exit.150: ; preds = %while.hdr.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 1 }) - ret { ptr, i64 } %callN - -if.then.151: ; preds = %while.body.149 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.152 - -if.merge.152: ; preds = %if.then.151, %while.body.149 - %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.387, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, 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 @@ -4231,27 +4040,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.133 + +fv.default: ; preds = %if.merge.137 + br label %fv.merge + +fv.case: ; preds = %if.merge.137 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.137 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.137 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 10 }, { ptr, i64 } { ptr @str.371, 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.138 + +while.hdr.138: ; preds = %if.merge.142, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.139, label %while.exit.140 + +while.body.139: ; preds = %while.hdr.138 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.141, label %if.merge.142 + +while.exit.140: ; preds = %while.hdr.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 1 }) + ret { ptr, i64 } %callN + +if.then.141: ; preds = %while.body.139 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.142 + +if.merge.142: ; preds = %if.then.141, %while.body.139 + %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.374, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.138 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 3 }, { ptr, i64 } { ptr @str.377, 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.143 + +while.hdr.143: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.144, label %while.exit.145 + +while.body.144: ; preds = %while.hdr.143 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.146, label %if.merge.147 + +while.exit.145: ; preds = %while.hdr.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) + ret { ptr, i64 } %callN + +if.then.146: ; preds = %while.body.144 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.147 + +if.merge.147: ; preds = %if.then.146, %while.body.144 + %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.381, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.143 + +fv.default: ; preds = %if.merge.147 + br label %fv.merge + +fv.case: ; preds = %if.merge.147 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 10 }, { ptr, i64 } { ptr @str.384, 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.148 + +while.hdr.148: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.149, label %while.exit.150 + +while.body.149: ; preds = %while.hdr.148 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.151, label %if.merge.152 + +while.exit.150: ; preds = %while.hdr.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) + ret { ptr, i64 } %callN + +if.then.151: ; preds = %while.body.149 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.152 + +if.merge.152: ; preds = %if.then.151, %while.body.149 + %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.389, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.148 fv.default: ; preds = %if.merge.152 br label %fv.merge fv.case: ; preds = %if.merge.152 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.152 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.152 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4261,7 +4270,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.389, i64 5 }, { ptr, i64 } { ptr @str.390, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.391, i64 5 }, { ptr, i64 } { ptr @str.392, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4280,24 +4289,24 @@ while.body.154: ; preds = %while.hdr.153 while.exit.155: ; preds = %while.hdr.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 1 }) ret { ptr, i64 } %callN if.then.156: ; preds = %while.body.154 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.157 if.merge.157: ; preds = %if.then.156, %while.body.154 %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.396, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.398, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, 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 @@ -4324,7 +4333,7 @@ fv.default: ; preds = %if.merge.157 fv.case: ; preds = %if.merge.157 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.157 @@ -4336,7 +4345,7 @@ fv.case20: ; preds = %if.merge.157 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4345,7 +4354,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 8 }, { ptr, i64 } { ptr @str.399, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 8 }, { ptr, i64 } { ptr @str.401, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4364,24 +4373,24 @@ while.body.159: ; preds = %while.hdr.158 while.exit.160: ; preds = %while.hdr.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 1 }) ret { ptr, i64 } %callN if.then.161: ; preds = %while.body.159 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.162 if.merge.162: ; preds = %if.then.161, %while.body.159 %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.405, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, 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 @@ -4428,7 +4437,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 17 }, { ptr, i64 } { ptr @str.408, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 17 }, { ptr, i64 } { ptr @str.410, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4447,24 +4456,24 @@ while.body.164: ; preds = %while.hdr.163 while.exit.165: ; preds = %while.hdr.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) ret { ptr, i64 } %callN if.then.166: ; preds = %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.167 if.merge.167: ; preds = %if.then.166, %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4493,7 +4502,7 @@ fv.case: ; preds = %if.merge.167 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.167 @@ -4518,7 +4527,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 7 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 7 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4537,24 +4546,24 @@ while.body.169: ; preds = %while.hdr.168 while.exit.170: ; preds = %while.hdr.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.171: ; preds = %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.172 if.merge.172: ; preds = %if.then.171, %while.body.169 %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.423, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.425, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, 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 @@ -4581,7 +4590,7 @@ fv.case: ; preds = %if.merge.172 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.172 @@ -4596,7 +4605,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.425, i64 4 }, { ptr, i64 } { ptr @str.426, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.427, i64 4 }, { ptr, i64 } { ptr @str.428, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4615,24 +4624,24 @@ while.body.174: ; preds = %while.hdr.173 while.exit.175: ; preds = %while.hdr.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 1 }) ret { ptr, i64 } %callN if.then.176: ; preds = %while.body.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.177 if.merge.177: ; preds = %if.then.176, %while.body.174 %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.430, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.432, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4669,7 +4678,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.432, i64 10 }, { ptr, i64 } { ptr @str.433, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.434, i64 10 }, { ptr, i64 } { ptr @str.435, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4688,24 +4697,24 @@ while.body.179: ; preds = %while.hdr.178 while.exit.180: ; preds = %while.hdr.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 1 }) ret { ptr, i64 } %callN if.then.181: ; preds = %while.body.179 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.182 if.merge.182: ; preds = %if.then.181, %while.body.179 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.441, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.443, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4771,7 +4780,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 13 }, { ptr, i64 } { ptr @str.444, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 13 }, { ptr, i64 } { ptr @str.446, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4790,24 +4799,24 @@ while.body.184: ; preds = %while.hdr.183 while.exit.185: ; preds = %while.hdr.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 1 }) ret { ptr, i64 } %callN if.then.186: ; preds = %while.body.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.187 if.merge.187: ; preds = %if.then.186, %while.body.184 %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.449, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.451, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4849,7 +4858,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.451, i64 8 }, { ptr, i64 } { ptr @str.452, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.453, i64 8 }, { ptr, i64 } { ptr @str.454, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4868,24 +4877,24 @@ while.body.189: ; preds = %while.hdr.188 while.exit.190: ; preds = %while.hdr.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 1 }) ret { ptr, i64 } %callN if.then.191: ; preds = %while.body.189 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.192 if.merge.192: ; preds = %if.then.191, %while.body.189 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.460, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.462, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4946,7 +4955,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 5 }, { ptr, i64 } { ptr @str.463, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.464, i64 5 }, { ptr, i64 } { ptr @str.465, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4965,24 +4974,24 @@ while.body.194: ; preds = %while.hdr.193 while.exit.195: ; preds = %while.hdr.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 1 }) ret { ptr, i64 } %callN if.then.196: ; preds = %while.body.194 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.197 if.merge.197: ; preds = %if.then.196, %while.body.194 %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.469, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.471, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, 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 @@ -5028,7 +5037,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 6 }, { ptr, i64 } { ptr @str.472, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 6 }, { ptr, i64 } { ptr @str.474, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5047,24 +5056,24 @@ while.body.199: ; preds = %while.hdr.198 while.exit.200: ; preds = %while.hdr.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) ret { ptr, i64 } %callN if.then.201: ; preds = %while.body.199 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.202 if.merge.202: ; preds = %if.then.201, %while.body.199 %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.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, 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 @@ -5112,7 +5121,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 6 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 6 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5131,24 +5140,24 @@ while.body.204: ; preds = %while.hdr.203 while.exit.205: ; preds = %while.hdr.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.206: ; preds = %while.body.204 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.207 if.merge.207: ; preds = %if.then.206, %while.body.204 %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.486, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.488, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5192,7 +5201,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 4 }, { ptr, i64 } { ptr @str.489, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 4 }, { ptr, i64 } { ptr @str.491, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5211,24 +5220,24 @@ while.body.209: ; preds = %while.hdr.208 while.exit.210: ; preds = %while.hdr.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) ret { ptr, i64 } %callN if.then.211: ; preds = %while.body.209 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.212 if.merge.212: ; preds = %if.then.211, %while.body.209 %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.495, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.497, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5278,7 +5287,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 6 }, { ptr, i64 } { ptr @str.498, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 6 }, { ptr, i64 } { ptr @str.500, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5297,24 +5306,24 @@ while.body.214: ; preds = %while.hdr.213 while.exit.215: ; preds = %while.hdr.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) ret { ptr, i64 } %callN if.then.216: ; preds = %while.body.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.217 if.merge.217: ; preds = %if.then.216, %while.body.214 %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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.506, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5354,7 +5363,7 @@ fv.case20: ; preds = %if.merge.217 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5363,7 +5372,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 12 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 12 }, { ptr, i64 } { ptr @str.509, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5382,24 +5391,24 @@ while.body.219: ; preds = %while.hdr.218 while.exit.220: ; preds = %while.hdr.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) ret { ptr, i64 } %callN if.then.221: ; preds = %while.body.219 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.222 if.merge.222: ; preds = %if.then.221, %while.body.219 %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.510, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.512, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5419,7 +5428,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 8 }, { ptr, i64 } { ptr @str.513, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.514, i64 8 }, { ptr, i64 } { ptr @str.515, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5438,24 +5447,24 @@ while.body.224: ; preds = %while.hdr.223 while.exit.225: ; preds = %while.hdr.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 1 }) ret { ptr, i64 } %callN if.then.226: ; preds = %while.body.224 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.227 if.merge.227: ; preds = %if.then.226, %while.body.224 %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.519, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.521, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5507,7 +5516,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 7 }, { ptr, i64 } { ptr @str.522, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 7 }, { ptr, i64 } { ptr @str.524, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5526,24 +5535,24 @@ while.body.229: ; preds = %while.hdr.228 while.exit.230: ; preds = %while.hdr.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 1 }) ret { ptr, i64 } %callN if.then.231: ; preds = %while.body.229 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.232 if.merge.232: ; preds = %if.then.231, %while.body.229 %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.528, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.530, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5595,7 +5604,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 9 }, { ptr, i64 } { ptr @str.531, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.532, i64 9 }, { ptr, i64 } { ptr @str.533, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5614,24 +5623,24 @@ while.body.234: ; preds = %while.hdr.233 while.exit.235: ; preds = %while.hdr.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 1 }) ret { ptr, i64 } %callN if.then.236: ; preds = %while.body.234 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.237 if.merge.237: ; preds = %if.then.236, %while.body.234 %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.536, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.538, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5674,7 +5683,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 4 }, { ptr, i64 } { ptr @str.539, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.540, i64 4 }, { ptr, i64 } { ptr @str.541, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5693,24 +5702,24 @@ while.body.239: ; preds = %while.hdr.238 while.exit.240: ; preds = %while.hdr.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 1 }) ret { ptr, i64 } %callN if.then.241: ; preds = %while.body.239 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.242 if.merge.242: ; preds = %if.then.241, %while.body.239 %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.544, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.546, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5756,7 +5765,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.548, i64 6 }, { ptr, i64 } { ptr @str.549, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5775,24 +5784,24 @@ while.body.244: ; preds = %while.hdr.243 while.exit.245: ; preds = %while.hdr.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 1 }) ret { ptr, i64 } %callN if.then.246: ; preds = %while.body.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.247 if.merge.247: ; preds = %if.then.246, %while.body.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.557, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.558, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5874,7 +5883,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, i64 6 }, { ptr, i64 } { ptr @str.560, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 6 }, { ptr, i64 } { ptr @str.562, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5893,24 +5902,24 @@ while.body.249: ; preds = %while.hdr.248 while.exit.250: ; preds = %while.hdr.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) ret { ptr, i64 } %callN if.then.251: ; preds = %while.body.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.564, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.252 if.merge.252: ; preds = %if.then.251, %while.body.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.567, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.569, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5965,7 +5974,7 @@ define internal { ptr, i64 } @struct_to_string__IntCell(ptr %0, { i64 } %1) #0 { entry: %alloca = alloca { i64 }, align 8 store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 7 }, { ptr, i64 } { ptr @str.570, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 7 }, { ptr, i64 } { ptr @str.572, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5984,24 +5993,24 @@ while.body.254: ; preds = %while.hdr.253 while.exit.255: ; preds = %while.hdr.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 1 }) ret { ptr, i64 } %callN if.then.256: ; preds = %while.body.254 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.257 if.merge.257: ; preds = %if.then.256, %while.body.254 %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.574, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.576, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, 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 @@ -6034,7 +6043,7 @@ define internal { ptr, i64 } @struct_to_string__R(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } { ptr @str.577, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } { ptr @str.579, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6053,24 +6062,24 @@ while.body.259: ; preds = %while.hdr.258 while.exit.260: ; preds = %while.hdr.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 1 }) ret { ptr, i64 } %callN if.then.261: ; preds = %while.body.259 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 if.merge.262: ; preds = %if.then.261, %while.body.259 %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.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.582, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6089,7 +6098,7 @@ define internal { ptr, i64 } @struct_to_string__Combined(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, i64 8 }, { ptr, i64 } { ptr @str.583, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 8 }, { ptr, i64 } { ptr @str.585, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6108,24 +6117,24 @@ while.body.264: ; preds = %while.hdr.263 while.exit.265: ; preds = %while.hdr.263 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.586, i64 1 }) ret { ptr, i64 } %callN if.then.266: ; preds = %while.body.264 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.267 if.merge.267: ; preds = %if.then.266, %while.body.264 %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.586, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.588, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6144,7 +6153,7 @@ define internal { ptr, i64 } @struct_to_string__VL__s64(ptr %0, { ptr, ptr } %1) entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 7 }, { ptr, i64 } { ptr @str.589, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 7 }, { ptr, i64 } { ptr @str.591, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6163,24 +6172,24 @@ while.body.269: ; preds = %while.hdr.268 while.exit.270: ; preds = %while.hdr.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 1 }) ret { ptr, i64 } %callN if.then.271: ; preds = %while.body.269 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 if.merge.272: ; preds = %if.then.271, %while.body.269 %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.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6221,7 +6230,7 @@ define internal { ptr, i64 } @struct_to_string____VL__s64__Vtable(ptr %0, { ptr entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.596, i64 17 }, { ptr, i64 } { ptr @str.597, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, i64 17 }, { ptr, i64 } { ptr @str.599, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6240,24 +6249,24 @@ while.body.274: ; preds = %while.hdr.273 while.exit.275: ; preds = %while.hdr.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) ret { ptr, i64 } %callN if.then.276: ; preds = %while.body.274 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.277 if.merge.277: ; preds = %if.then.276, %while.body.274 %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.601, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6291,7 +6300,7 @@ define internal { ptr, i64 } @struct_to_string__VL(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.603, i64 2 }, { ptr, i64 } { ptr @str.604, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.605, i64 2 }, { ptr, i64 } { ptr @str.606, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6310,24 +6319,24 @@ while.body.279: ; preds = %while.hdr.278 while.exit.280: ; preds = %while.hdr.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %callN if.then.281: ; preds = %while.body.279 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.282 if.merge.282: ; preds = %if.then.281, %while.body.279 %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.607, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.609, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6347,7 +6356,7 @@ entry: %alloca = alloca { { { ptr, ptr } }, i64 }, align 8 %ba.tmp = alloca { { ptr, ptr } }, align 8 store { { { ptr, ptr } }, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.609, i64 18 }, { ptr, i64 } { ptr @str.610, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.611, i64 18 }, { ptr, i64 } { ptr @str.612, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6366,24 +6375,24 @@ while.body.284: ; preds = %while.hdr.283 while.exit.285: ; preds = %while.hdr.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %callN if.then.286: ; preds = %while.body.284 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.287 if.merge.287: ; preds = %if.then.286, %while.body.284 %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.615, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.617, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { { ptr, ptr } }, i64 }, ptr %alloca, align 8 @@ -6428,9 +6437,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.622, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.624, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.617, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.619, 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 @@ -6449,8 +6458,8 @@ entry: if.then.295: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.623, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6469,9 +6478,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.629, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.631, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.627, 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 @@ -6490,8 +6499,8 @@ entry: if.then.297: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.298 @@ -6521,9 +6530,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.639, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.641, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6540,8 +6549,8 @@ entry: if.then.299: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.641, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.643, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6619,9 +6628,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.650, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.652, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, 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 @@ -6640,8 +6649,8 @@ entry: if.then.301: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.652, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.654, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.302 @@ -6660,9 +6669,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.659, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.661, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, 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 @@ -6681,8 +6690,8 @@ entry: if.then.303: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.304 @@ -6699,7 +6708,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.662, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.664, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6716,12 +6725,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6750,7 +6759,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.665, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.667, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6767,12 +6776,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6802,7 +6811,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.668, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.670, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6819,12 +6828,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6852,7 +6861,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.671, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.673, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6869,12 +6878,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6903,7 +6912,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.674, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.676, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.333 @@ -6920,12 +6929,12 @@ while.body.334: ; preds = %while.hdr.333 while.exit.335: ; preds = %while.hdr.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 1 }) ret { ptr, i64 } %call if.then.336: ; preds = %while.body.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.337 @@ -6954,7 +6963,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.677, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.679, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.338 @@ -6971,12 +6980,12 @@ while.body.339: ; preds = %while.hdr.338 while.exit.340: ; preds = %while.hdr.338 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 1 }) ret { ptr, i64 } %call if.then.341: ; preds = %while.body.339 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.342 @@ -7006,7 +7015,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.680, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.682, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.351 @@ -7025,12 +7034,12 @@ while.body.352: ; preds = %while.hdr.351 while.exit.353: ; preds = %while.hdr.351 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 1 }) ret { ptr, i64 } %call if.then.354: ; preds = %while.body.352 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.355 @@ -7059,7 +7068,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.683, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.685, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.356 @@ -7078,12 +7087,12 @@ while.body.357: ; preds = %while.hdr.356 while.exit.358: ; preds = %while.hdr.356 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 1 }) ret { ptr, i64 } %call if.then.359: ; preds = %while.body.357 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.360 @@ -7112,7 +7121,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.686, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.688, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.361 @@ -7131,12 +7140,12 @@ while.body.362: ; preds = %while.hdr.361 while.exit.363: ; preds = %while.hdr.361 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 1 }) ret { ptr, i64 } %call if.then.364: ; preds = %while.body.362 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.365 @@ -7166,7 +7175,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.689, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.691, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.366 @@ -7185,12 +7194,12 @@ while.body.367: ; preds = %while.hdr.366 while.exit.368: ; preds = %while.hdr.366 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 1 }) ret { ptr, i64 } %call if.then.369: ; preds = %while.body.367 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.370 @@ -7220,7 +7229,7 @@ entry: %ba.tmp = alloca {}, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.692, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.694, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.371 @@ -7239,12 +7248,12 @@ while.body.372: ; preds = %while.hdr.371 while.exit.373: ; preds = %while.hdr.371 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 1 }) ret { ptr, i64 } %call if.then.374: ; preds = %while.body.372 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.375 @@ -7274,7 +7283,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.695, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.697, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.376 @@ -7293,12 +7302,12 @@ while.body.377: ; preds = %while.hdr.376 while.exit.378: ; preds = %while.hdr.376 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.698, i64 1 }) ret { ptr, i64 } %call if.then.379: ; preds = %while.body.377 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.699, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.380 @@ -7340,12 +7349,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 5 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7368,12 +7377,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 11 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7396,12 +7405,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 4 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7424,12 +7433,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 11 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7452,12 +7461,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 6 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7479,12 +7488,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 5 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7507,12 +7516,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 9 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7535,12 +7544,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 18 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7563,12 +7572,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 5 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7591,12 +7600,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7619,12 +7628,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 4 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7647,12 +7656,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 9 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7675,12 +7684,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 4 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7702,12 +7711,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 8 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7730,12 +7739,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 6 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7757,12 +7766,12 @@ if.then.478: ; preds = %entry if.else.479: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 9 }, { ptr, i64 } %callN) br label %if.merge.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7785,12 +7794,12 @@ if.then.481: ; preds = %entry if.else.482: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 7 }, { ptr, i64 } %callN) br label %if.merge.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7813,12 +7822,12 @@ if.then.484: ; preds = %entry if.else.485: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 5 }, { ptr, i64 } %callN) br label %if.merge.486 if.merge.486: ; preds = %if.else.485, %if.then.484 - %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -7841,12 +7850,12 @@ if.then.487: ; preds = %entry if.else.488: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 7 }, { ptr, i64 } %callN) br label %if.merge.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -7869,12 +7878,12 @@ if.then.490: ; preds = %entry if.else.491: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 4 }, { ptr, i64 } %callN) br label %if.merge.492 if.merge.492: ; preds = %if.else.491, %if.then.490 - %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -7897,12 +7906,12 @@ if.then.493: ; preds = %entry if.else.494: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 7 }, { ptr, i64 } %callN) br label %if.merge.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -7925,12 +7934,12 @@ if.then.496: ; preds = %entry if.else.497: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 5 }, { ptr, i64 } %callN) br label %if.merge.498 if.merge.498: ; preds = %if.else.497, %if.then.496 - %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -7953,12 +7962,12 @@ if.then.499: ; preds = %entry if.else.500: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 7 }, { ptr, i64 } %callN) br label %if.merge.501 if.merge.501: ; preds = %if.else.500, %if.then.499 - %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -7981,12 +7990,12 @@ if.then.502: ; preds = %entry if.else.503: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 8 }, { ptr, i64 } %callN) br label %if.merge.504 if.merge.504: ; preds = %if.else.503, %if.then.502 - %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] ret { ptr, i64 } %bp } @@ -8009,12 +8018,12 @@ if.then.505: ; preds = %entry if.else.506: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 12 }, { ptr, i64 } %callN) br label %if.merge.507 if.merge.507: ; preds = %if.else.506, %if.then.505 - %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] ret { ptr, i64 } %bp } @@ -8037,12 +8046,12 @@ if.then.508: ; preds = %entry if.else.509: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 6 }, { ptr, i64 } %callN) br label %if.merge.510 if.merge.510: ; preds = %if.else.509, %if.then.508 - %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] ret { ptr, i64 } %bp } @@ -8065,12 +8074,12 @@ if.then.511: ; preds = %entry if.else.512: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 4 }, { ptr, i64 } %callN) br label %if.merge.513 if.merge.513: ; preds = %if.else.512, %if.then.511 - %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] ret { ptr, i64 } %bp } @@ -8093,12 +8102,12 @@ if.then.514: ; preds = %entry if.else.515: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 7 }, { ptr, i64 } %callN) br label %if.merge.516 if.merge.516: ; preds = %if.else.515, %if.then.514 - %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] ret { ptr, i64 } %bp } @@ -8121,12 +8130,12 @@ if.then.517: ; preds = %entry if.else.518: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 6 }, { ptr, i64 } %callN) br label %if.merge.519 if.merge.519: ; preds = %if.else.518, %if.then.517 - %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] ret { ptr, i64 } %bp } @@ -8149,12 +8158,12 @@ if.then.520: ; preds = %entry if.else.521: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 19 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 19 }, { ptr, i64 } %callN) br label %if.merge.522 if.merge.522: ; preds = %if.else.521, %if.then.520 - %bp = phi { ptr, i64 } [ { ptr @str.785, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] + %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] ret { ptr, i64 } %bp } @@ -8177,12 +8186,12 @@ if.then.523: ; preds = %entry if.else.524: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 9 }, { ptr, i64 } %callN) br label %if.merge.525 if.merge.525: ; preds = %if.else.524, %if.then.523 - %bp = phi { ptr, i64 } [ { ptr @str.788, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] + %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] ret { ptr, i64 } %bp } @@ -8205,12 +8214,12 @@ if.then.526: ; preds = %entry if.else.527: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 18 }, { ptr, i64 } %callN) br label %if.merge.528 if.merge.528: ; preds = %if.else.527, %if.then.526 - %bp = phi { ptr, i64 } [ { ptr @str.791, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] + %bp = phi { ptr, i64 } [ { ptr @str.793, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] ret { ptr, i64 } %bp } @@ -8233,12 +8242,12 @@ if.then.529: ; preds = %entry if.else.530: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 6 }, { ptr, i64 } %callN) br label %if.merge.531 if.merge.531: ; preds = %if.else.530, %if.then.529 - %bp = phi { ptr, i64 } [ { ptr @str.794, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] + %bp = phi { ptr, i64 } [ { ptr @str.796, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] ret { ptr, i64 } %bp } @@ -8261,12 +8270,12 @@ if.then.532: ; preds = %entry if.else.533: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 20 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 20 }, { ptr, i64 } %callN) br label %if.merge.534 if.merge.534: ; preds = %if.else.533, %if.then.532 - %bp = phi { ptr, i64 } [ { ptr @str.797, i64 4 }, %if.then.532 ], [ %callN, %if.else.533 ] + %bp = phi { ptr, i64 } [ { ptr @str.799, i64 4 }, %if.then.532 ], [ %callN, %if.else.533 ] ret { ptr, i64 } %bp } @@ -8289,12 +8298,12 @@ if.then.535: ; preds = %entry if.else.536: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 8 }, { ptr, i64 } %callN) br label %if.merge.537 if.merge.537: ; preds = %if.else.536, %if.then.535 - %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.535 ], [ %callN, %if.else.536 ] + %bp = phi { ptr, i64 } [ { ptr @str.802, i64 4 }, %if.then.535 ], [ %callN, %if.else.536 ] ret { ptr, i64 } %bp } @@ -8317,12 +8326,12 @@ if.then.538: ; preds = %entry if.else.539: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 7 }, { ptr, i64 } %callN) br label %if.merge.540 if.merge.540: ; preds = %if.else.539, %if.then.538 - %bp = phi { ptr, i64 } [ { ptr @str.803, i64 4 }, %if.then.538 ], [ %callN, %if.else.539 ] + %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.538 ], [ %callN, %if.else.539 ] ret { ptr, i64 } %bp } @@ -8345,12 +8354,12 @@ if.then.541: ; preds = %entry if.else.542: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 5 }, { ptr, i64 } %callN) br label %if.merge.543 if.merge.543: ; preds = %if.else.542, %if.then.541 - %bp = phi { ptr, i64 } [ { ptr @str.806, i64 4 }, %if.then.541 ], [ %callN, %if.else.542 ] + %bp = phi { ptr, i64 } [ { ptr @str.808, i64 4 }, %if.then.541 ], [ %callN, %if.else.542 ] ret { ptr, i64 } %bp } @@ -8366,7 +8375,7 @@ entry: br i1 %lnot, label %if.then.550, label %if.merge.551 if.then.550: ; preds = %entry - ret { ptr, i64 } { ptr @str.809, i64 4 } + ret { ptr, i64 } { ptr @str.811, i64 4 } if.merge.551: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8390,7 +8399,7 @@ entry: br i1 %lnot, label %if.then.552, label %if.merge.553 if.then.552: ; preds = %entry - ret { ptr, i64 } { ptr @str.810, i64 4 } + ret { ptr, i64 } { ptr @str.812, i64 4 } if.merge.553: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8414,7 +8423,7 @@ entry: br i1 %lnot, label %if.then.554, label %if.merge.555 if.then.554: ; preds = %entry - ret { ptr, i64 } { ptr @str.811, i64 4 } + ret { ptr, i64 } { ptr @str.813, i64 4 } if.merge.555: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8438,7 +8447,7 @@ entry: br i1 %lnot, label %if.then.556, label %if.merge.557 if.then.556: ; preds = %entry - ret { ptr, i64 } { ptr @str.812, i64 4 } + ret { ptr, i64 } { ptr @str.814, i64 4 } if.merge.557: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0416-protocols-auto-type-erasure.ir b/examples/expected/0416-protocols-auto-type-erasure.ir index f3d3aaf..b28ee8f 100644 --- a/examples/expected/0416-protocols-auto-type-erasure.ir +++ b/examples/expected/0416-protocols-auto-type-erasure.ir @@ -2,753 +2,753 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @__Counter__SimpleCounter__vtable = internal constant { ptr, ptr } { ptr @__thunk_SimpleCounter_Counter_inc, ptr @__thunk_SimpleCounter_Counter_get } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.467 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.468 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.469 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.470 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.471 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.471 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.472 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.473 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.475 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.476 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [189 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.472 = private constant [9 x i8] c"Overflow\00" -@tag.str.473 = private constant [3 x i8] c"Io\00" -@tag.str.474 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.475 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.476 = private constant [10 x i8] c"BadEscape\00" -@tag.str.477 = private constant [10 x i8] c"BadNumber\00" -@tag.str.478 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.479 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.480 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.481 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.482 = private constant [13 x i8] c"MissingValue\00" -@tag.str.483 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.484 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.472, i64 8 }, { ptr, i64 } { ptr @tag.str.473, i64 2 }, { ptr, i64 } { ptr @tag.str.474, i64 15 }, { ptr, i64 } { ptr @tag.str.475, i64 13 }, { ptr, i64 } { ptr @tag.str.476, i64 9 }, { ptr, i64 } { ptr @tag.str.477, i64 9 }, { ptr, i64 } { ptr @tag.str.478, i64 15 }, { ptr, i64 } { ptr @tag.str.479, i64 14 }, { ptr, i64 } { ptr @tag.str.480, i64 14 }, { ptr, i64 } { ptr @tag.str.481, i64 11 }, { ptr, i64 } { ptr @tag.str.482, i64 12 }, { ptr, i64 } { ptr @tag.str.483, i64 15 }, { ptr, i64 } { ptr @tag.str.484, i64 12 }] +@tag.str.477 = private constant [9 x i8] c"Overflow\00" +@tag.str.478 = private constant [3 x i8] c"Io\00" +@tag.str.479 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.480 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.481 = private constant [10 x i8] c"BadEscape\00" +@tag.str.482 = private constant [10 x i8] c"BadNumber\00" +@tag.str.483 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.484 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.485 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.486 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.487 = private constant [13 x i8] c"MissingValue\00" +@tag.str.488 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.489 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.477, i64 8 }, { ptr, i64 } { ptr @tag.str.478, i64 2 }, { ptr, i64 } { ptr @tag.str.479, i64 15 }, { ptr, i64 } { ptr @tag.str.480, i64 13 }, { ptr, i64 } { ptr @tag.str.481, i64 9 }, { ptr, i64 } { ptr @tag.str.482, i64 9 }, { ptr, i64 } { ptr @tag.str.483, i64 15 }, { ptr, i64 } { ptr @tag.str.484, i64 14 }, { ptr, i64 } { ptr @tag.str.485, i64 14 }, { ptr, i64 } { ptr @tag.str.486, i64 11 }, { ptr, i64 } { ptr @tag.str.487, i64 12 }, { ptr, i64 } { ptr @tag.str.488, i64 15 }, { ptr, i64 } { ptr @tag.str.489, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.485 = private constant [5 x i8] c"bool\00" -@tn.str.486 = private constant [3 x i8] c"s8\00" -@tn.str.487 = private constant [4 x i8] c"s16\00" -@tn.str.488 = private constant [4 x i8] c"s32\00" -@tn.str.489 = private constant [4 x i8] c"s64\00" -@tn.str.490 = private constant [3 x i8] c"u8\00" -@tn.str.491 = private constant [4 x i8] c"u16\00" -@tn.str.492 = private constant [4 x i8] c"u32\00" -@tn.str.493 = private constant [4 x i8] c"u64\00" -@tn.str.494 = private constant [4 x i8] c"f32\00" -@tn.str.495 = private constant [4 x i8] c"f64\00" -@tn.str.496 = private constant [7 x i8] c"string\00" -@tn.str.497 = private constant [4 x i8] c"Any\00" -@tn.str.498 = private constant [9 x i8] c"noreturn\00" -@tn.str.499 = private constant [6 x i8] c"isize\00" -@tn.str.500 = private constant [6 x i8] c"usize\00" -@tn.str.501 = private constant [5 x i8] c"void\00" -@tn.str.502 = private constant [6 x i8] c"*void\00" -@tn.str.503 = private constant [16 x i8] c"Source_Location\00" -@tn.str.504 = private constant [11 x i8] c"CAllocator\00" -@tn.str.505 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.506 = private constant [4 x i8] c"GPA\00" -@tn.str.507 = private constant [5 x i8] c"*GPA\00" -@tn.str.508 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.509 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.510 = private constant [10 x i8] c"Allocator\00" -@tn.str.511 = private constant [6 x i8] c"Arena\00" -@tn.str.512 = private constant [7 x i8] c"*Arena\00" -@tn.str.513 = private constant [6 x i8] c"[*]u8\00" -@tn.str.514 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.515 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.516 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.517 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.518 = private constant [8 x i8] c"Context\00" -@tn.str.519 = private constant [7 x i8] c"[4]s64\00" -@tn.str.520 = private constant [9 x i8] c"[]string\00" -@tn.str.521 = private constant [9 x i8] c"OpenMode\00" -@tn.str.522 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.523 = private constant [5 x i8] c"File\00" -@tn.str.524 = private constant [6 x i8] c"*File\00" -@tn.str.525 = private constant [6 x i8] c"?File\00" -@tn.str.526 = private constant [8 x i8] c"?string\00" -@tn.str.527 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.528 = private constant [4 x i8] c"*u8\00" -@tn.str.529 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.530 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.531 = private constant [5 x i8] c"*s32\00" -@tn.str.532 = private constant [9 x i8] c"SockAddr\00" -@tn.str.533 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.534 = private constant [5 x i8] c"*u32\00" -@tn.str.535 = private constant [10 x i8] c"JsonError\00" -@tn.str.536 = private constant [6 x i8] c"Array\00" -@tn.str.537 = private constant [7 x i8] c"Object\00" -@tn.str.538 = private constant [6 x i8] c"Value\00" -@tn.str.539 = private constant [7 x i8] c"Member\00" -@tn.str.540 = private constant [9 x i8] c"[*]Value\00" -@tn.str.541 = private constant [7 x i8] c"*Array\00" -@tn.str.542 = private constant [10 x i8] c"[*]Member\00" -@tn.str.543 = private constant [8 x i8] c"*Object\00" -@tn.str.544 = private constant [5 x i8] c"[]u8\00" -@tn.str.545 = private constant [5 x i8] c"Sink\00" -@tn.str.546 = private constant [6 x i8] c"*Sink\00" -@tn.str.547 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.548 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.549 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.550 = private constant [7 x i8] c"Parser\00" -@tn.str.551 = private constant [8 x i8] c"*Parser\00" -@tn.str.552 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.553 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.554 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.555 = private constant [13 x i8] c"Architecture\00" -@tn.str.556 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.557 = private constant [11 x i8] c"() -> bool\00" -@tn.str.558 = private constant [5 x i8] c"*s64\00" -@tn.str.559 = private constant [9 x i8] c"CliError\00" -@tn.str.560 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.561 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.562 = private constant [8 x i8] c"Command\00" -@tn.str.563 = private constant [10 x i8] c"FlagValue\00" -@tn.str.564 = private constant [5 x i8] c"Diag\00" -@tn.str.565 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.566 = private constant [7 x i8] c"Parsed\00" -@tn.str.567 = private constant [8 x i8] c"*Parsed\00" -@tn.str.568 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.569 = private constant [10 x i8] c"[]Command\00" -@tn.str.570 = private constant [6 x i8] c"*Diag\00" -@tn.str.571 = private constant [7 x i8] c"[8]s64\00" -@tn.str.572 = private constant [7 x i8] c"[64]u8\00" -@tn.str.573 = private constant [7 x i8] c"Sha256\00" -@tn.str.574 = private constant [8 x i8] c"*Sha256\00" -@tn.str.575 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.576 = private constant [8 x i8] c"[64]s64\00" -@tn.str.577 = private constant [8 x i8] c"[16]f32\00" -@tn.str.578 = private constant [5 x i8] c"Mat4\00" -@tn.str.579 = private constant [5 x i8] c"Vec2\00" -@tn.str.580 = private constant [6 x i8] c"Point\00" -@tn.str.581 = private constant [8 x i8] c"Counter\00" -@tn.str.582 = private constant [18 x i8] c"__Counter__Vtable\00" -@tn.str.583 = private constant [9 x i8] c"Summable\00" -@tn.str.584 = private constant [19 x i8] c"__Summable__Vtable\00" -@tn.str.585 = private constant [14 x i8] c"SimpleCounter\00" -@tn.str.586 = private constant [15 x i8] c"*SimpleCounter\00" -@tn.str.587 = private constant [7 x i8] c"*Point\00" -@tn.str.588 = private constant [6 x i8] c"Adder\00" -@tn.str.589 = private constant [12 x i8] c"Accumulator\00" -@tn.str.590 = private constant [13 x i8] c"*Accumulator\00" -@tn.str.591 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.592 = private constant [7 x i8] c"**void\00" -@tn.str.593 = private constant [8 x i8] c"*string\00" -@tn.str.594 = private constant [6 x i8] c"[]Any\00" -@tn.str.595 = private constant [5 x i8] c"*Any\00" -@tn.str.596 = private constant [7 x i8] c"*[]Any\00" -@tn.str.597 = private constant [6 x i8] c"*bool\00" -@tn.str.598 = private constant [9 x i8] c"*Counter\00" -@tn.str.599 = private constant [16 x i8] c"**SimpleCounter\00" -@tn.str.600 = private constant [19 x i8] c"*__Counter__Vtable\00" -@tn.str.601 = private constant [7 x i8] c"[1]Any\00" -@tn.str.602 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.603 = private constant [7 x i8] c"*Adder\00" -@tn.str.604 = private constant [14 x i8] c"**Accumulator\00" -@tn.str.605 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.606 = private constant [5 x i8] c"*f64\00" -@tn.str.607 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.608 = private constant [11 x i8] c"*Allocator\00" -@tn.str.609 = private constant [9 x i8] c"*Context\00" -@tn.str.610 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.611 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.612 = private constant [8 x i8] c"*Member\00" -@tn.str.613 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.614 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.615 = private constant [9 x i8] c"*Command\00" -@tn.str.616 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.617 = private constant [6 x i8] c"*Mat4\00" -@tn.str.618 = private constant [6 x i8] c"*Vec2\00" -@tn.str.619 = private constant [10 x i8] c"*Summable\00" -@tn.str.620 = private constant [20 x i8] c"*__Summable__Vtable\00" -@tn.str.621 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.622 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.623 = private constant [7 x i8] c"*Value\00" -@tn.str.624 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.625 = private constant [14 x i8] c"*Architecture\00" -@tn.str.626 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.627 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.628 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.629 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.630 = private constant [9 x i8] c"*[16]f32\00" -@tn.str.631 = private constant [10 x i8] c"*[]string\00" -@tn.str.632 = private constant [6 x i8] c"*[]u8\00" -@tn.str.633 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.634 = private constant [11 x i8] c"*[]Command\00" -@tn.str.635 = private constant [6 x i8] c"**GPA\00" -@tn.str.636 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.637 = private constant [8 x i8] c"**Arena\00" -@tn.str.638 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.639 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.640 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.641 = private constant [7 x i8] c"**File\00" -@tn.str.642 = private constant [5 x i8] c"**u8\00" -@tn.str.643 = private constant [6 x i8] c"**s32\00" -@tn.str.644 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.645 = private constant [6 x i8] c"**u32\00" -@tn.str.646 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.647 = private constant [8 x i8] c"**Array\00" -@tn.str.648 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.649 = private constant [9 x i8] c"**Object\00" -@tn.str.650 = private constant [7 x i8] c"**Sink\00" -@tn.str.651 = private constant [9 x i8] c"**Parser\00" -@tn.str.652 = private constant [6 x i8] c"**s64\00" -@tn.str.653 = private constant [9 x i8] c"**Parsed\00" -@tn.str.654 = private constant [7 x i8] c"**Diag\00" -@tn.str.655 = private constant [9 x i8] c"**Sha256\00" -@tn.str.656 = private constant [8 x i8] c"**Point\00" -@tn.str.657 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.658 = private constant [8 x i8] c"***void\00" -@tn.str.659 = private constant [9 x i8] c"**string\00" -@tn.str.660 = private constant [6 x i8] c"**Any\00" -@tn.str.661 = private constant [8 x i8] c"**[]Any\00" -@tn.str.662 = private constant [7 x i8] c"**bool\00" -@tn.str.663 = private constant [10 x i8] c"**Counter\00" -@tn.str.664 = private constant [17 x i8] c"***SimpleCounter\00" -@tn.str.665 = private constant [20 x i8] c"**__Counter__Vtable\00" -@tn.str.666 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.667 = private constant [8 x i8] c"**Adder\00" -@tn.str.668 = private constant [15 x i8] c"***Accumulator\00" -@tn.str.669 = private constant [7 x i8] c"*?File\00" -@tn.str.670 = private constant [9 x i8] c"*?string\00" -@tn.str.671 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.672 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [189 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.485, i64 4 }, { ptr, i64 } { ptr @tn.str.486, i64 2 }, { ptr, i64 } { ptr @tn.str.487, i64 3 }, { ptr, i64 } { ptr @tn.str.488, i64 3 }, { ptr, i64 } { ptr @tn.str.489, i64 3 }, { ptr, i64 } { ptr @tn.str.490, i64 2 }, { ptr, i64 } { ptr @tn.str.491, i64 3 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 3 }, { ptr, i64 } { ptr @tn.str.495, i64 3 }, { ptr, i64 } { ptr @tn.str.496, i64 6 }, { ptr, i64 } { ptr @tn.str.497, i64 3 }, { ptr, i64 } { ptr @tn.str.498, i64 8 }, { ptr, i64 } { ptr @tn.str.499, i64 5 }, { ptr, i64 } { ptr @tn.str.500, i64 5 }, { ptr, i64 } { ptr @tn.str.501, i64 4 }, { ptr, i64 } { ptr @tn.str.502, i64 5 }, { ptr, i64 } { ptr @tn.str.503, i64 15 }, { ptr, i64 } { ptr @tn.str.504, i64 10 }, { ptr, i64 } { ptr @tn.str.505, i64 11 }, { ptr, i64 } { ptr @tn.str.506, i64 3 }, { ptr, i64 } { ptr @tn.str.507, i64 4 }, { ptr, i64 } { ptr @tn.str.508, i64 10 }, { ptr, i64 } { ptr @tn.str.509, i64 11 }, { ptr, i64 } { ptr @tn.str.510, i64 9 }, { ptr, i64 } { ptr @tn.str.511, i64 5 }, { ptr, i64 } { ptr @tn.str.512, i64 6 }, { ptr, i64 } { ptr @tn.str.513, i64 5 }, { ptr, i64 } { ptr @tn.str.514, i64 8 }, { ptr, i64 } { ptr @tn.str.515, i64 9 }, { ptr, i64 } { ptr @tn.str.516, i64 17 }, { ptr, i64 } { ptr @tn.str.517, i64 18 }, { ptr, i64 } { ptr @tn.str.518, i64 7 }, { ptr, i64 } { ptr @tn.str.519, i64 6 }, { ptr, i64 } { ptr @tn.str.520, i64 8 }, { ptr, i64 } { ptr @tn.str.521, i64 8 }, { ptr, i64 } { ptr @tn.str.522, i64 8 }, { ptr, i64 } { ptr @tn.str.523, i64 4 }, { ptr, i64 } { ptr @tn.str.524, i64 5 }, { ptr, i64 } { ptr @tn.str.525, i64 5 }, { ptr, i64 } { ptr @tn.str.526, i64 7 }, { ptr, i64 } { ptr @tn.str.527, i64 10 }, { ptr, i64 } { ptr @tn.str.528, i64 3 }, { ptr, i64 } { ptr @tn.str.529, i64 13 }, { ptr, i64 } { ptr @tn.str.530, i64 14 }, { ptr, i64 } { ptr @tn.str.531, i64 4 }, { ptr, i64 } { ptr @tn.str.532, i64 8 }, { ptr, i64 } { ptr @tn.str.533, i64 9 }, { ptr, i64 } { ptr @tn.str.534, i64 4 }, { ptr, i64 } { ptr @tn.str.535, i64 9 }, { ptr, i64 } { ptr @tn.str.536, i64 5 }, { ptr, i64 } { ptr @tn.str.537, i64 6 }, { ptr, i64 } { ptr @tn.str.538, i64 5 }, { ptr, i64 } { ptr @tn.str.539, i64 6 }, { ptr, i64 } { ptr @tn.str.540, i64 8 }, { ptr, i64 } { ptr @tn.str.541, i64 6 }, { ptr, i64 } { ptr @tn.str.542, i64 9 }, { ptr, i64 } { ptr @tn.str.543, i64 7 }, { ptr, i64 } { ptr @tn.str.544, i64 4 }, { ptr, i64 } { ptr @tn.str.545, i64 4 }, { ptr, i64 } { ptr @tn.str.546, i64 5 }, { ptr, i64 } { ptr @tn.str.547, i64 16 }, { ptr, i64 } { ptr @tn.str.548, i64 14 }, { ptr, i64 } { ptr @tn.str.549, i64 21 }, { ptr, i64 } { ptr @tn.str.550, i64 6 }, { ptr, i64 } { ptr @tn.str.551, i64 7 }, { ptr, i64 } { ptr @tn.str.552, i64 24 }, { ptr, i64 } { ptr @tn.str.553, i64 23 }, { ptr, i64 } { ptr @tn.str.554, i64 15 }, { ptr, i64 } { ptr @tn.str.555, i64 12 }, { ptr, i64 } { ptr @tn.str.556, i64 12 }, { ptr, i64 } { ptr @tn.str.557, i64 10 }, { ptr, i64 } { ptr @tn.str.558, i64 4 }, { ptr, i64 } { ptr @tn.str.559, i64 8 }, { ptr, i64 } { ptr @tn.str.560, i64 8 }, { ptr, i64 } { ptr @tn.str.561, i64 10 }, { ptr, i64 } { ptr @tn.str.562, i64 7 }, { ptr, i64 } { ptr @tn.str.563, i64 9 }, { ptr, i64 } { ptr @tn.str.564, i64 4 }, { ptr, i64 } { ptr @tn.str.565, i64 13 }, { ptr, i64 } { ptr @tn.str.566, i64 6 }, { ptr, i64 } { ptr @tn.str.567, i64 7 }, { ptr, i64 } { ptr @tn.str.568, i64 18 }, { ptr, i64 } { ptr @tn.str.569, i64 9 }, { ptr, i64 } { ptr @tn.str.570, i64 5 }, { ptr, i64 } { ptr @tn.str.571, i64 6 }, { ptr, i64 } { ptr @tn.str.572, i64 6 }, { ptr, i64 } { ptr @tn.str.573, i64 6 }, { ptr, i64 } { ptr @tn.str.574, i64 7 }, { ptr, i64 } { ptr @tn.str.575, i64 7 }, { ptr, i64 } { ptr @tn.str.576, i64 7 }, { ptr, i64 } { ptr @tn.str.577, i64 7 }, { ptr, i64 } { ptr @tn.str.578, i64 4 }, { ptr, i64 } { ptr @tn.str.579, i64 4 }, { ptr, i64 } { ptr @tn.str.580, i64 5 }, { ptr, i64 } { ptr @tn.str.581, i64 7 }, { ptr, i64 } { ptr @tn.str.582, i64 17 }, { ptr, i64 } { ptr @tn.str.583, i64 8 }, { ptr, i64 } { ptr @tn.str.584, i64 18 }, { ptr, i64 } { ptr @tn.str.585, i64 13 }, { ptr, i64 } { ptr @tn.str.586, i64 14 }, { ptr, i64 } { ptr @tn.str.587, i64 6 }, { ptr, i64 } { ptr @tn.str.588, i64 5 }, { ptr, i64 } { ptr @tn.str.589, i64 11 }, { ptr, i64 } { ptr @tn.str.590, i64 12 }, { ptr, i64 } { ptr @tn.str.591, i64 12 }, { ptr, i64 } { ptr @tn.str.592, i64 6 }, { ptr, i64 } { ptr @tn.str.593, i64 7 }, { ptr, i64 } { ptr @tn.str.594, i64 5 }, { ptr, i64 } { ptr @tn.str.595, i64 4 }, { ptr, i64 } { ptr @tn.str.596, i64 6 }, { ptr, i64 } { ptr @tn.str.597, i64 5 }, { ptr, i64 } { ptr @tn.str.598, i64 8 }, { ptr, i64 } { ptr @tn.str.599, i64 15 }, { ptr, i64 } { ptr @tn.str.600, i64 18 }, { ptr, i64 } { ptr @tn.str.601, i64 6 }, { ptr, i64 } { ptr @tn.str.602, i64 7 }, { ptr, i64 } { ptr @tn.str.603, i64 6 }, { ptr, i64 } { ptr @tn.str.604, i64 13 }, { ptr, i64 } { ptr @tn.str.605, i64 7 }, { ptr, i64 } { ptr @tn.str.606, i64 4 }, { ptr, i64 } { ptr @tn.str.607, i64 16 }, { ptr, i64 } { ptr @tn.str.608, i64 10 }, { ptr, i64 } { ptr @tn.str.609, i64 8 }, { ptr, i64 } { ptr @tn.str.610, i64 11 }, { ptr, i64 } { ptr @tn.str.611, i64 14 }, { ptr, i64 } { ptr @tn.str.612, i64 7 }, { ptr, i64 } { ptr @tn.str.613, i64 13 }, { ptr, i64 } { ptr @tn.str.614, i64 9 }, { ptr, i64 } { ptr @tn.str.615, i64 8 }, { ptr, i64 } { ptr @tn.str.616, i64 10 }, { ptr, i64 } { ptr @tn.str.617, i64 5 }, { ptr, i64 } { ptr @tn.str.618, i64 5 }, { ptr, i64 } { ptr @tn.str.619, i64 9 }, { ptr, i64 } { ptr @tn.str.620, i64 19 }, { ptr, i64 } { ptr @tn.str.621, i64 9 }, { ptr, i64 } { ptr @tn.str.622, i64 9 }, { ptr, i64 } { ptr @tn.str.623, i64 6 }, { ptr, i64 } { ptr @tn.str.624, i64 16 }, { ptr, i64 } { ptr @tn.str.625, i64 13 }, { ptr, i64 } { ptr @tn.str.626, i64 14 }, { ptr, i64 } { ptr @tn.str.627, i64 7 }, { ptr, i64 } { ptr @tn.str.628, i64 7 }, { ptr, i64 } { ptr @tn.str.629, i64 8 }, { ptr, i64 } { ptr @tn.str.630, i64 8 }, { ptr, i64 } { ptr @tn.str.631, i64 9 }, { ptr, i64 } { ptr @tn.str.632, i64 5 }, { ptr, i64 } { ptr @tn.str.633, i64 11 }, { ptr, i64 } { ptr @tn.str.634, i64 10 }, { ptr, i64 } { ptr @tn.str.635, i64 5 }, { ptr, i64 } { ptr @tn.str.636, i64 12 }, { ptr, i64 } { ptr @tn.str.637, i64 7 }, { ptr, i64 } { ptr @tn.str.638, i64 6 }, { ptr, i64 } { ptr @tn.str.639, i64 10 }, { ptr, i64 } { ptr @tn.str.640, i64 19 }, { ptr, i64 } { ptr @tn.str.641, i64 6 }, { ptr, i64 } { ptr @tn.str.642, i64 4 }, { ptr, i64 } { ptr @tn.str.643, i64 5 }, { ptr, i64 } { ptr @tn.str.644, i64 10 }, { ptr, i64 } { ptr @tn.str.645, i64 5 }, { ptr, i64 } { ptr @tn.str.646, i64 9 }, { ptr, i64 } { ptr @tn.str.647, i64 7 }, { ptr, i64 } { ptr @tn.str.648, i64 10 }, { ptr, i64 } { ptr @tn.str.649, i64 8 }, { ptr, i64 } { ptr @tn.str.650, i64 6 }, { ptr, i64 } { ptr @tn.str.651, i64 8 }, { ptr, i64 } { ptr @tn.str.652, i64 5 }, { ptr, i64 } { ptr @tn.str.653, i64 8 }, { ptr, i64 } { ptr @tn.str.654, i64 6 }, { ptr, i64 } { ptr @tn.str.655, i64 8 }, { ptr, i64 } { ptr @tn.str.656, i64 7 }, { ptr, i64 } { ptr @tn.str.657, i64 13 }, { ptr, i64 } { ptr @tn.str.658, i64 7 }, { ptr, i64 } { ptr @tn.str.659, i64 8 }, { ptr, i64 } { ptr @tn.str.660, i64 5 }, { ptr, i64 } { ptr @tn.str.661, i64 7 }, { ptr, i64 } { ptr @tn.str.662, i64 6 }, { ptr, i64 } { ptr @tn.str.663, i64 9 }, { ptr, i64 } { ptr @tn.str.664, i64 16 }, { ptr, i64 } { ptr @tn.str.665, i64 19 }, { ptr, i64 } { ptr @tn.str.666, i64 8 }, { ptr, i64 } { ptr @tn.str.667, i64 7 }, { ptr, i64 } { ptr @tn.str.668, i64 14 }, { ptr, i64 } { ptr @tn.str.669, i64 6 }, { ptr, i64 } { ptr @tn.str.670, i64 8 }, { ptr, i64 } { ptr @tn.str.671, i64 15 }, { ptr, i64 } { ptr @tn.str.672, i64 8 }] -@str.673 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.674 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.675 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.676 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.677 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.490 = private constant [5 x i8] c"bool\00" +@tn.str.491 = private constant [3 x i8] c"s8\00" +@tn.str.492 = private constant [4 x i8] c"s16\00" +@tn.str.493 = private constant [4 x i8] c"s32\00" +@tn.str.494 = private constant [4 x i8] c"s64\00" +@tn.str.495 = private constant [3 x i8] c"u8\00" +@tn.str.496 = private constant [4 x i8] c"u16\00" +@tn.str.497 = private constant [4 x i8] c"u32\00" +@tn.str.498 = private constant [4 x i8] c"u64\00" +@tn.str.499 = private constant [4 x i8] c"f32\00" +@tn.str.500 = private constant [4 x i8] c"f64\00" +@tn.str.501 = private constant [7 x i8] c"string\00" +@tn.str.502 = private constant [4 x i8] c"Any\00" +@tn.str.503 = private constant [9 x i8] c"noreturn\00" +@tn.str.504 = private constant [6 x i8] c"isize\00" +@tn.str.505 = private constant [6 x i8] c"usize\00" +@tn.str.506 = private constant [5 x i8] c"void\00" +@tn.str.507 = private constant [6 x i8] c"*void\00" +@tn.str.508 = private constant [16 x i8] c"Source_Location\00" +@tn.str.509 = private constant [10 x i8] c"Allocator\00" +@tn.str.510 = private constant [11 x i8] c"CAllocator\00" +@tn.str.511 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.512 = private constant [4 x i8] c"GPA\00" +@tn.str.513 = private constant [5 x i8] c"*GPA\00" +@tn.str.514 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.515 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.516 = private constant [6 x i8] c"Arena\00" +@tn.str.517 = private constant [7 x i8] c"*Arena\00" +@tn.str.518 = private constant [6 x i8] c"[*]u8\00" +@tn.str.519 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.520 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.521 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.522 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.523 = private constant [8 x i8] c"Context\00" +@tn.str.524 = private constant [7 x i8] c"[4]s64\00" +@tn.str.525 = private constant [9 x i8] c"[]string\00" +@tn.str.526 = private constant [9 x i8] c"OpenMode\00" +@tn.str.527 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.528 = private constant [5 x i8] c"File\00" +@tn.str.529 = private constant [6 x i8] c"*File\00" +@tn.str.530 = private constant [6 x i8] c"?File\00" +@tn.str.531 = private constant [8 x i8] c"?string\00" +@tn.str.532 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.533 = private constant [4 x i8] c"*u8\00" +@tn.str.534 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.535 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.536 = private constant [5 x i8] c"*s32\00" +@tn.str.537 = private constant [9 x i8] c"SockAddr\00" +@tn.str.538 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.539 = private constant [5 x i8] c"*u32\00" +@tn.str.540 = private constant [10 x i8] c"JsonError\00" +@tn.str.541 = private constant [6 x i8] c"Array\00" +@tn.str.542 = private constant [7 x i8] c"Object\00" +@tn.str.543 = private constant [6 x i8] c"Value\00" +@tn.str.544 = private constant [7 x i8] c"Member\00" +@tn.str.545 = private constant [9 x i8] c"[*]Value\00" +@tn.str.546 = private constant [7 x i8] c"*Array\00" +@tn.str.547 = private constant [10 x i8] c"[*]Member\00" +@tn.str.548 = private constant [8 x i8] c"*Object\00" +@tn.str.549 = private constant [5 x i8] c"[]u8\00" +@tn.str.550 = private constant [5 x i8] c"Sink\00" +@tn.str.551 = private constant [6 x i8] c"*Sink\00" +@tn.str.552 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.553 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.554 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.555 = private constant [7 x i8] c"Parser\00" +@tn.str.556 = private constant [8 x i8] c"*Parser\00" +@tn.str.557 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.558 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.559 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.560 = private constant [13 x i8] c"Architecture\00" +@tn.str.561 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.562 = private constant [11 x i8] c"() -> bool\00" +@tn.str.563 = private constant [5 x i8] c"*s64\00" +@tn.str.564 = private constant [9 x i8] c"CliError\00" +@tn.str.565 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.566 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.567 = private constant [8 x i8] c"Command\00" +@tn.str.568 = private constant [10 x i8] c"FlagValue\00" +@tn.str.569 = private constant [5 x i8] c"Diag\00" +@tn.str.570 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.571 = private constant [7 x i8] c"Parsed\00" +@tn.str.572 = private constant [8 x i8] c"*Parsed\00" +@tn.str.573 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.574 = private constant [10 x i8] c"[]Command\00" +@tn.str.575 = private constant [6 x i8] c"*Diag\00" +@tn.str.576 = private constant [7 x i8] c"[8]s64\00" +@tn.str.577 = private constant [7 x i8] c"[64]u8\00" +@tn.str.578 = private constant [7 x i8] c"Sha256\00" +@tn.str.579 = private constant [8 x i8] c"*Sha256\00" +@tn.str.580 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.581 = private constant [8 x i8] c"[64]s64\00" +@tn.str.582 = private constant [8 x i8] c"[16]f32\00" +@tn.str.583 = private constant [5 x i8] c"Mat4\00" +@tn.str.584 = private constant [5 x i8] c"Vec2\00" +@tn.str.585 = private constant [6 x i8] c"Point\00" +@tn.str.586 = private constant [8 x i8] c"Counter\00" +@tn.str.587 = private constant [18 x i8] c"__Counter__Vtable\00" +@tn.str.588 = private constant [9 x i8] c"Summable\00" +@tn.str.589 = private constant [19 x i8] c"__Summable__Vtable\00" +@tn.str.590 = private constant [14 x i8] c"SimpleCounter\00" +@tn.str.591 = private constant [15 x i8] c"*SimpleCounter\00" +@tn.str.592 = private constant [7 x i8] c"*Point\00" +@tn.str.593 = private constant [6 x i8] c"Adder\00" +@tn.str.594 = private constant [12 x i8] c"Accumulator\00" +@tn.str.595 = private constant [13 x i8] c"*Accumulator\00" +@tn.str.596 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.597 = private constant [7 x i8] c"**void\00" +@tn.str.598 = private constant [8 x i8] c"*string\00" +@tn.str.599 = private constant [6 x i8] c"[]Any\00" +@tn.str.600 = private constant [5 x i8] c"*Any\00" +@tn.str.601 = private constant [7 x i8] c"*[]Any\00" +@tn.str.602 = private constant [6 x i8] c"*bool\00" +@tn.str.603 = private constant [9 x i8] c"*Counter\00" +@tn.str.604 = private constant [16 x i8] c"**SimpleCounter\00" +@tn.str.605 = private constant [19 x i8] c"*__Counter__Vtable\00" +@tn.str.606 = private constant [7 x i8] c"[1]Any\00" +@tn.str.607 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.608 = private constant [7 x i8] c"*Adder\00" +@tn.str.609 = private constant [14 x i8] c"**Accumulator\00" +@tn.str.610 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.611 = private constant [5 x i8] c"*f64\00" +@tn.str.612 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.613 = private constant [11 x i8] c"*Allocator\00" +@tn.str.614 = private constant [9 x i8] c"*Context\00" +@tn.str.615 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.616 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.617 = private constant [8 x i8] c"*Member\00" +@tn.str.618 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.619 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.620 = private constant [9 x i8] c"*Command\00" +@tn.str.621 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.622 = private constant [6 x i8] c"*Mat4\00" +@tn.str.623 = private constant [6 x i8] c"*Vec2\00" +@tn.str.624 = private constant [10 x i8] c"*Summable\00" +@tn.str.625 = private constant [20 x i8] c"*__Summable__Vtable\00" +@tn.str.626 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.627 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.628 = private constant [7 x i8] c"*Value\00" +@tn.str.629 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.630 = private constant [14 x i8] c"*Architecture\00" +@tn.str.631 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.632 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.633 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.634 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.635 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.636 = private constant [10 x i8] c"*[]string\00" +@tn.str.637 = private constant [6 x i8] c"*[]u8\00" +@tn.str.638 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.639 = private constant [11 x i8] c"*[]Command\00" +@tn.str.640 = private constant [6 x i8] c"**GPA\00" +@tn.str.641 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.642 = private constant [8 x i8] c"**Arena\00" +@tn.str.643 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.644 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.645 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.646 = private constant [7 x i8] c"**File\00" +@tn.str.647 = private constant [5 x i8] c"**u8\00" +@tn.str.648 = private constant [6 x i8] c"**s32\00" +@tn.str.649 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.650 = private constant [6 x i8] c"**u32\00" +@tn.str.651 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.652 = private constant [8 x i8] c"**Array\00" +@tn.str.653 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.654 = private constant [9 x i8] c"**Object\00" +@tn.str.655 = private constant [7 x i8] c"**Sink\00" +@tn.str.656 = private constant [9 x i8] c"**Parser\00" +@tn.str.657 = private constant [6 x i8] c"**s64\00" +@tn.str.658 = private constant [9 x i8] c"**Parsed\00" +@tn.str.659 = private constant [7 x i8] c"**Diag\00" +@tn.str.660 = private constant [9 x i8] c"**Sha256\00" +@tn.str.661 = private constant [8 x i8] c"**Point\00" +@tn.str.662 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.663 = private constant [8 x i8] c"***void\00" +@tn.str.664 = private constant [9 x i8] c"**string\00" +@tn.str.665 = private constant [6 x i8] c"**Any\00" +@tn.str.666 = private constant [8 x i8] c"**[]Any\00" +@tn.str.667 = private constant [7 x i8] c"**bool\00" +@tn.str.668 = private constant [10 x i8] c"**Counter\00" +@tn.str.669 = private constant [17 x i8] c"***SimpleCounter\00" +@tn.str.670 = private constant [20 x i8] c"**__Counter__Vtable\00" +@tn.str.671 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.672 = private constant [8 x i8] c"**Adder\00" +@tn.str.673 = private constant [15 x i8] c"***Accumulator\00" +@tn.str.674 = private constant [7 x i8] c"*?File\00" +@tn.str.675 = private constant [9 x i8] c"*?string\00" +@tn.str.676 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.677 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [189 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.490, i64 4 }, { ptr, i64 } { ptr @tn.str.491, i64 2 }, { ptr, i64 } { ptr @tn.str.492, i64 3 }, { ptr, i64 } { ptr @tn.str.493, i64 3 }, { ptr, i64 } { ptr @tn.str.494, i64 3 }, { ptr, i64 } { ptr @tn.str.495, i64 2 }, { ptr, i64 } { ptr @tn.str.496, i64 3 }, { ptr, i64 } { ptr @tn.str.497, i64 3 }, { ptr, i64 } { ptr @tn.str.498, i64 3 }, { ptr, i64 } { ptr @tn.str.499, i64 3 }, { ptr, i64 } { ptr @tn.str.500, i64 3 }, { ptr, i64 } { ptr @tn.str.501, i64 6 }, { ptr, i64 } { ptr @tn.str.502, i64 3 }, { ptr, i64 } { ptr @tn.str.503, i64 8 }, { ptr, i64 } { ptr @tn.str.504, i64 5 }, { ptr, i64 } { ptr @tn.str.505, i64 5 }, { ptr, i64 } { ptr @tn.str.506, i64 4 }, { ptr, i64 } { ptr @tn.str.507, i64 5 }, { ptr, i64 } { ptr @tn.str.508, i64 15 }, { ptr, i64 } { ptr @tn.str.509, i64 9 }, { ptr, i64 } { ptr @tn.str.510, i64 10 }, { ptr, i64 } { ptr @tn.str.511, i64 11 }, { ptr, i64 } { ptr @tn.str.512, i64 3 }, { ptr, i64 } { ptr @tn.str.513, i64 4 }, { ptr, i64 } { ptr @tn.str.514, i64 10 }, { ptr, i64 } { ptr @tn.str.515, i64 11 }, { ptr, i64 } { ptr @tn.str.516, i64 5 }, { ptr, i64 } { ptr @tn.str.517, i64 6 }, { ptr, i64 } { ptr @tn.str.518, i64 5 }, { ptr, i64 } { ptr @tn.str.519, i64 8 }, { ptr, i64 } { ptr @tn.str.520, i64 9 }, { ptr, i64 } { ptr @tn.str.521, i64 17 }, { ptr, i64 } { ptr @tn.str.522, i64 18 }, { ptr, i64 } { ptr @tn.str.523, i64 7 }, { ptr, i64 } { ptr @tn.str.524, i64 6 }, { ptr, i64 } { ptr @tn.str.525, i64 8 }, { ptr, i64 } { ptr @tn.str.526, i64 8 }, { ptr, i64 } { ptr @tn.str.527, i64 8 }, { ptr, i64 } { ptr @tn.str.528, i64 4 }, { ptr, i64 } { ptr @tn.str.529, i64 5 }, { ptr, i64 } { ptr @tn.str.530, i64 5 }, { ptr, i64 } { ptr @tn.str.531, i64 7 }, { ptr, i64 } { ptr @tn.str.532, i64 10 }, { ptr, i64 } { ptr @tn.str.533, i64 3 }, { ptr, i64 } { ptr @tn.str.534, i64 13 }, { ptr, i64 } { ptr @tn.str.535, i64 14 }, { ptr, i64 } { ptr @tn.str.536, i64 4 }, { ptr, i64 } { ptr @tn.str.537, i64 8 }, { ptr, i64 } { ptr @tn.str.538, i64 9 }, { ptr, i64 } { ptr @tn.str.539, i64 4 }, { ptr, i64 } { ptr @tn.str.540, i64 9 }, { ptr, i64 } { ptr @tn.str.541, i64 5 }, { ptr, i64 } { ptr @tn.str.542, i64 6 }, { ptr, i64 } { ptr @tn.str.543, i64 5 }, { ptr, i64 } { ptr @tn.str.544, i64 6 }, { ptr, i64 } { ptr @tn.str.545, i64 8 }, { ptr, i64 } { ptr @tn.str.546, i64 6 }, { ptr, i64 } { ptr @tn.str.547, i64 9 }, { ptr, i64 } { ptr @tn.str.548, i64 7 }, { ptr, i64 } { ptr @tn.str.549, i64 4 }, { ptr, i64 } { ptr @tn.str.550, i64 4 }, { ptr, i64 } { ptr @tn.str.551, i64 5 }, { ptr, i64 } { ptr @tn.str.552, i64 16 }, { ptr, i64 } { ptr @tn.str.553, i64 14 }, { ptr, i64 } { ptr @tn.str.554, i64 21 }, { ptr, i64 } { ptr @tn.str.555, i64 6 }, { ptr, i64 } { ptr @tn.str.556, i64 7 }, { ptr, i64 } { ptr @tn.str.557, i64 24 }, { ptr, i64 } { ptr @tn.str.558, i64 23 }, { ptr, i64 } { ptr @tn.str.559, i64 15 }, { ptr, i64 } { ptr @tn.str.560, i64 12 }, { ptr, i64 } { ptr @tn.str.561, i64 12 }, { ptr, i64 } { ptr @tn.str.562, i64 10 }, { ptr, i64 } { ptr @tn.str.563, i64 4 }, { ptr, i64 } { ptr @tn.str.564, i64 8 }, { ptr, i64 } { ptr @tn.str.565, i64 8 }, { ptr, i64 } { ptr @tn.str.566, i64 10 }, { ptr, i64 } { ptr @tn.str.567, i64 7 }, { ptr, i64 } { ptr @tn.str.568, i64 9 }, { ptr, i64 } { ptr @tn.str.569, i64 4 }, { ptr, i64 } { ptr @tn.str.570, i64 13 }, { ptr, i64 } { ptr @tn.str.571, i64 6 }, { ptr, i64 } { ptr @tn.str.572, i64 7 }, { ptr, i64 } { ptr @tn.str.573, i64 18 }, { ptr, i64 } { ptr @tn.str.574, i64 9 }, { ptr, i64 } { ptr @tn.str.575, i64 5 }, { ptr, i64 } { ptr @tn.str.576, i64 6 }, { ptr, i64 } { ptr @tn.str.577, i64 6 }, { ptr, i64 } { ptr @tn.str.578, i64 6 }, { ptr, i64 } { ptr @tn.str.579, i64 7 }, { ptr, i64 } { ptr @tn.str.580, i64 7 }, { ptr, i64 } { ptr @tn.str.581, i64 7 }, { ptr, i64 } { ptr @tn.str.582, i64 7 }, { ptr, i64 } { ptr @tn.str.583, i64 4 }, { ptr, i64 } { ptr @tn.str.584, i64 4 }, { ptr, i64 } { ptr @tn.str.585, i64 5 }, { ptr, i64 } { ptr @tn.str.586, i64 7 }, { ptr, i64 } { ptr @tn.str.587, i64 17 }, { ptr, i64 } { ptr @tn.str.588, i64 8 }, { ptr, i64 } { ptr @tn.str.589, i64 18 }, { ptr, i64 } { ptr @tn.str.590, i64 13 }, { ptr, i64 } { ptr @tn.str.591, i64 14 }, { ptr, i64 } { ptr @tn.str.592, i64 6 }, { ptr, i64 } { ptr @tn.str.593, i64 5 }, { ptr, i64 } { ptr @tn.str.594, i64 11 }, { ptr, i64 } { ptr @tn.str.595, i64 12 }, { ptr, i64 } { ptr @tn.str.596, i64 12 }, { ptr, i64 } { ptr @tn.str.597, i64 6 }, { ptr, i64 } { ptr @tn.str.598, i64 7 }, { ptr, i64 } { ptr @tn.str.599, i64 5 }, { ptr, i64 } { ptr @tn.str.600, i64 4 }, { ptr, i64 } { ptr @tn.str.601, i64 6 }, { ptr, i64 } { ptr @tn.str.602, i64 5 }, { ptr, i64 } { ptr @tn.str.603, i64 8 }, { ptr, i64 } { ptr @tn.str.604, i64 15 }, { ptr, i64 } { ptr @tn.str.605, i64 18 }, { ptr, i64 } { ptr @tn.str.606, i64 6 }, { ptr, i64 } { ptr @tn.str.607, i64 7 }, { ptr, i64 } { ptr @tn.str.608, i64 6 }, { ptr, i64 } { ptr @tn.str.609, i64 13 }, { ptr, i64 } { ptr @tn.str.610, i64 7 }, { ptr, i64 } { ptr @tn.str.611, i64 4 }, { ptr, i64 } { ptr @tn.str.612, i64 16 }, { ptr, i64 } { ptr @tn.str.613, i64 10 }, { ptr, i64 } { ptr @tn.str.614, i64 8 }, { ptr, i64 } { ptr @tn.str.615, i64 11 }, { ptr, i64 } { ptr @tn.str.616, i64 14 }, { ptr, i64 } { ptr @tn.str.617, i64 7 }, { ptr, i64 } { ptr @tn.str.618, i64 13 }, { ptr, i64 } { ptr @tn.str.619, i64 9 }, { ptr, i64 } { ptr @tn.str.620, i64 8 }, { ptr, i64 } { ptr @tn.str.621, i64 10 }, { ptr, i64 } { ptr @tn.str.622, i64 5 }, { ptr, i64 } { ptr @tn.str.623, i64 5 }, { ptr, i64 } { ptr @tn.str.624, i64 9 }, { ptr, i64 } { ptr @tn.str.625, i64 19 }, { ptr, i64 } { ptr @tn.str.626, i64 9 }, { ptr, i64 } { ptr @tn.str.627, i64 9 }, { ptr, i64 } { ptr @tn.str.628, i64 6 }, { ptr, i64 } { ptr @tn.str.629, i64 16 }, { ptr, i64 } { ptr @tn.str.630, i64 13 }, { ptr, i64 } { ptr @tn.str.631, i64 14 }, { ptr, i64 } { ptr @tn.str.632, i64 7 }, { ptr, i64 } { ptr @tn.str.633, i64 7 }, { ptr, i64 } { ptr @tn.str.634, i64 8 }, { ptr, i64 } { ptr @tn.str.635, i64 8 }, { ptr, i64 } { ptr @tn.str.636, i64 9 }, { ptr, i64 } { ptr @tn.str.637, i64 5 }, { ptr, i64 } { ptr @tn.str.638, i64 11 }, { ptr, i64 } { ptr @tn.str.639, i64 10 }, { ptr, i64 } { ptr @tn.str.640, i64 5 }, { ptr, i64 } { ptr @tn.str.641, i64 12 }, { ptr, i64 } { ptr @tn.str.642, i64 7 }, { ptr, i64 } { ptr @tn.str.643, i64 6 }, { ptr, i64 } { ptr @tn.str.644, i64 10 }, { ptr, i64 } { ptr @tn.str.645, i64 19 }, { ptr, i64 } { ptr @tn.str.646, i64 6 }, { ptr, i64 } { ptr @tn.str.647, i64 4 }, { ptr, i64 } { ptr @tn.str.648, i64 5 }, { ptr, i64 } { ptr @tn.str.649, i64 10 }, { ptr, i64 } { ptr @tn.str.650, i64 5 }, { ptr, i64 } { ptr @tn.str.651, i64 9 }, { ptr, i64 } { ptr @tn.str.652, i64 7 }, { ptr, i64 } { ptr @tn.str.653, i64 10 }, { ptr, i64 } { ptr @tn.str.654, i64 8 }, { ptr, i64 } { ptr @tn.str.655, i64 6 }, { ptr, i64 } { ptr @tn.str.656, i64 8 }, { ptr, i64 } { ptr @tn.str.657, i64 5 }, { ptr, i64 } { ptr @tn.str.658, i64 8 }, { ptr, i64 } { ptr @tn.str.659, i64 6 }, { ptr, i64 } { ptr @tn.str.660, i64 8 }, { ptr, i64 } { ptr @tn.str.661, i64 7 }, { ptr, i64 } { ptr @tn.str.662, i64 13 }, { ptr, i64 } { ptr @tn.str.663, i64 7 }, { ptr, i64 } { ptr @tn.str.664, i64 8 }, { ptr, i64 } { ptr @tn.str.665, i64 5 }, { ptr, i64 } { ptr @tn.str.666, i64 7 }, { ptr, i64 } { ptr @tn.str.667, i64 6 }, { ptr, i64 } { ptr @tn.str.668, i64 9 }, { ptr, i64 } { ptr @tn.str.669, i64 16 }, { ptr, i64 } { ptr @tn.str.670, i64 19 }, { ptr, i64 } { ptr @tn.str.671, i64 8 }, { ptr, i64 } { ptr @tn.str.672, i64 7 }, { ptr, i64 } { ptr @tn.str.673, i64 14 }, { ptr, i64 } { ptr @tn.str.674, i64 6 }, { ptr, i64 } { ptr @tn.str.675, i64 8 }, { ptr, i64 } { ptr @tn.str.676, i64 15 }, { ptr, i64 } { ptr @tn.str.677, i64 8 }] @str.678 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.679 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.680 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.681 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.683 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.684 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.679 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.680 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.681 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.682 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.683 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.684 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 @str.685 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 @str.686 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.687 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.688 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.691 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.693 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.694 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 -@str.695 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.696 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 -@str.697 = private unnamed_addr constant [9 x i8] c"AE1: {}\0A\00", align 1 -@str.698 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.699 = private unnamed_addr constant [9 x i8] c"AE1: {}\0A\00", align 1 -@str.700 = private unnamed_addr constant [9 x i8] c"AE2: {}\0A\00", align 1 -@str.701 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.702 = private unnamed_addr constant [9 x i8] c"AE2: {}\0A\00", align 1 -@str.703 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 -@str.704 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.705 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 -@str.706 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 -@str.707 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.708 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 -@str.709 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 -@str.710 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.711 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 -@str.712 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.713 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.714 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.715 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.688 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.689 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.690 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.691 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.693 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.694 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.695 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.696 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.699 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 +@str.700 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.701 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 +@str.702 = private unnamed_addr constant [9 x i8] c"AE1: {}\0A\00", align 1 +@str.703 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.704 = private unnamed_addr constant [9 x i8] c"AE1: {}\0A\00", align 1 +@str.705 = private unnamed_addr constant [9 x i8] c"AE2: {}\0A\00", align 1 +@str.706 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.707 = private unnamed_addr constant [9 x i8] c"AE2: {}\0A\00", align 1 +@str.708 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 +@str.709 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.710 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 +@str.711 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 +@str.712 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.713 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 +@str.714 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 +@str.715 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.716 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 +@str.717 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.718 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.719 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.720 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.716 = private constant [5 x i8] c"line\00" -@fld.str.717 = private constant [4 x i8] c"col\00" -@fld.str.718 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.716, i64 4 }, { ptr, i64 } { ptr @fld.str.717, i64 3 }, { ptr, i64 } { ptr @fld.str.718, i64 4 }] -@str.719 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.720 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.721 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.722 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.723 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.724 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.725 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.726 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.727 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.728 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.729 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.730 = private constant [12 x i8] c"alloc_count\00" -@field_names.731 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.730, i64 11 }] -@str.732 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.733 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.734 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.735 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.736 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.737 = private constant [5 x i8] c"next\00" -@fld.str.738 = private constant [4 x i8] c"cap\00" -@field_names.739 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.737, i64 4 }, { ptr, i64 } { ptr @fld.str.738, i64 3 }] -@str.740 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.741 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.742 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.743 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.744 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.745 = private constant [4 x i8] c"ctx\00" -@fld.str.746 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.747 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.748 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.745, i64 3 }, { ptr, i64 } { ptr @fld.str.746, i64 11 }, { ptr, i64 } { ptr @fld.str.747, i64 13 }] -@str.749 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.750 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.751 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.752 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.753 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.754 = private constant [6 x i8] c"first\00" -@fld.str.755 = private constant [10 x i8] c"end_index\00" -@fld.str.756 = private constant [7 x i8] c"parent\00" -@field_names.757 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.754, i64 5 }, { ptr, i64 } { ptr @fld.str.755, i64 9 }, { ptr, i64 } { ptr @fld.str.756, i64 6 }] -@str.758 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.759 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.760 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.761 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.762 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.763 = private constant [4 x i8] c"buf\00" -@fld.str.764 = private constant [4 x i8] c"len\00" -@fld.str.765 = private constant [4 x i8] c"pos\00" -@field_names.766 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.763, i64 3 }, { ptr, i64 } { ptr @fld.str.764, i64 3 }, { ptr, i64 } { ptr @fld.str.765, i64 3 }] -@str.767 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.768 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.769 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.770 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.771 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.772 = private constant [7 x i8] c"parent\00" -@fld.str.773 = private constant [12 x i8] c"alloc_count\00" -@fld.str.774 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.775 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.776 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.772, i64 6 }, { ptr, i64 } { ptr @fld.str.773, i64 11 }, { ptr, i64 } { ptr @fld.str.774, i64 13 }, { ptr, i64 } { ptr @fld.str.775, i64 17 }] -@str.777 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.778 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.779 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.780 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.781 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.782 = private constant [10 x i8] c"allocator\00" -@fld.str.783 = private constant [5 x i8] c"data\00" -@field_names.784 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.782, i64 9 }, { ptr, i64 } { ptr @fld.str.783, i64 4 }] -@str.785 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.787 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.788 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.789 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.790 = private constant [3 x i8] c"fd\00" -@field_names.791 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.790, i64 2 }] -@str.792 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.793 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.794 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.795 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.796 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.797 = private constant [5 x i8] c"file\00" -@fld.str.798 = private constant [5 x i8] c"line\00" -@fld.str.799 = private constant [4 x i8] c"col\00" -@fld.str.800 = private constant [5 x i8] c"func\00" -@fld.str.801 = private constant [10 x i8] c"line_text\00" -@field_names.802 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.797, i64 4 }, { ptr, i64 } { ptr @fld.str.798, i64 4 }, { ptr, i64 } { ptr @fld.str.799, i64 3 }, { ptr, i64 } { ptr @fld.str.800, i64 4 }, { ptr, i64 } { ptr @fld.str.801, i64 9 }] -@str.803 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.804 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.805 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.806 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.807 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.808 = private constant [10 x i8] c"exit_code\00" -@fld.str.809 = private constant [7 x i8] c"stdout\00" -@field_names.810 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.808, i64 9 }, { ptr, i64 } { ptr @fld.str.809, i64 6 }] -@str.811 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.812 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.813 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.814 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.815 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.816 = private constant [8 x i8] c"sin_len\00" -@fld.str.817 = private constant [11 x i8] c"sin_family\00" -@fld.str.818 = private constant [9 x i8] c"sin_port\00" -@fld.str.819 = private constant [9 x i8] c"sin_addr\00" -@fld.str.820 = private constant [9 x i8] c"sin_zero\00" -@field_names.821 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.816, i64 7 }, { ptr, i64 } { ptr @fld.str.817, i64 10 }, { ptr, i64 } { ptr @fld.str.818, i64 8 }, { ptr, i64 } { ptr @fld.str.819, i64 8 }, { ptr, i64 } { ptr @fld.str.820, i64 8 }] -@str.822 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.823 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.824 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.825 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.826 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.827 = private constant [6 x i8] c"items\00" -@fld.str.828 = private constant [4 x i8] c"len\00" -@fld.str.829 = private constant [4 x i8] c"cap\00" -@field_names.830 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.827, i64 5 }, { ptr, i64 } { ptr @fld.str.828, i64 3 }, { ptr, i64 } { ptr @fld.str.829, i64 3 }] -@str.831 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.832 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.833 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.834 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.835 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.836 = private constant [6 x i8] c"items\00" -@fld.str.837 = private constant [4 x i8] c"len\00" -@fld.str.838 = private constant [4 x i8] c"cap\00" -@field_names.839 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.836, i64 5 }, { ptr, i64 } { ptr @fld.str.837, i64 3 }, { ptr, i64 } { ptr @fld.str.838, i64 3 }] -@str.840 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.841 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.842 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.843 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.844 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.845 = private constant [4 x i8] c"key\00" -@fld.str.846 = private constant [4 x i8] c"val\00" -@field_names.847 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.845, i64 3 }, { ptr, i64 } { ptr @fld.str.846, i64 3 }] -@str.848 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.849 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.850 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.851 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.852 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.853 = private constant [4 x i8] c"dst\00" -@fld.str.854 = private constant [4 x i8] c"pos\00" -@fld.str.855 = private constant [5 x i8] c"file\00" -@field_names.856 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.853, i64 3 }, { ptr, i64 } { ptr @fld.str.854, i64 3 }, { ptr, i64 } { ptr @fld.str.855, i64 4 }] -@str.857 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.858 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.859 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.860 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.861 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.862 = private constant [4 x i8] c"src\00" -@fld.str.863 = private constant [4 x i8] c"pos\00" -@fld.str.864 = private constant [6 x i8] c"alloc\00" -@field_names.865 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.862, i64 3 }, { ptr, i64 } { ptr @fld.str.863, i64 3 }, { ptr, i64 } { ptr @fld.str.864, i64 5 }] -@str.866 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.867 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.868 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.869 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.870 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.871 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.872 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.873 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.874 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.875 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.876 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.877 = private constant [5 x i8] c"name\00" -@fld.str.878 = private constant [12 x i8] c"takes_value\00" -@fld.str.879 = private constant [9 x i8] c"required\00" -@field_names.880 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.877, i64 4 }, { ptr, i64 } { ptr @fld.str.878, i64 11 }, { ptr, i64 } { ptr @fld.str.879, i64 8 }] -@str.881 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.882 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.883 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.884 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.885 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.886 = private constant [6 x i8] c"group\00" -@fld.str.887 = private constant [8 x i8] c"command\00" -@fld.str.888 = private constant [6 x i8] c"flags\00" -@field_names.889 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.886, i64 5 }, { ptr, i64 } { ptr @fld.str.887, i64 7 }, { ptr, i64 } { ptr @fld.str.888, i64 5 }] -@str.890 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.891 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.892 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.893 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.894 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.895 = private constant [4 x i8] c"set\00" -@fld.str.896 = private constant [6 x i8] c"value\00" -@field_names.897 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.895, i64 3 }, { ptr, i64 } { ptr @fld.str.896, i64 5 }] -@str.898 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.899 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.900 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.901 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.902 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.903 = private constant [6 x i8] c"index\00" -@fld.str.904 = private constant [6 x i8] c"token\00" -@field_names.905 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.903, i64 5 }, { ptr, i64 } { ptr @fld.str.904, i64 5 }] -@str.906 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.907 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.908 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.909 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.910 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.911 = private constant [6 x i8] c"group\00" -@fld.str.912 = private constant [8 x i8] c"command\00" -@fld.str.913 = private constant [10 x i8] c"cmd_index\00" -@fld.str.914 = private constant [5 x i8] c"json\00" -@fld.str.915 = private constant [5 x i8] c"rest\00" -@fld.str.916 = private constant [5 x i8] c"spec\00" -@fld.str.917 = private constant [7 x i8] c"values\00" -@field_names.918 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.911, i64 5 }, { ptr, i64 } { ptr @fld.str.912, i64 7 }, { ptr, i64 } { ptr @fld.str.913, i64 9 }, { ptr, i64 } { ptr @fld.str.914, i64 4 }, { ptr, i64 } { ptr @fld.str.915, i64 4 }, { ptr, i64 } { ptr @fld.str.916, i64 4 }, { ptr, i64 } { ptr @fld.str.917, i64 6 }] -@str.919 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.920 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.921 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.922 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.923 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.924 = private constant [2 x i8] c"h\00" -@fld.str.925 = private constant [4 x i8] c"buf\00" -@fld.str.926 = private constant [8 x i8] c"buf_len\00" -@fld.str.927 = private constant [10 x i8] c"total_len\00" -@field_names.928 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.924, i64 1 }, { ptr, i64 } { ptr @fld.str.925, i64 3 }, { ptr, i64 } { ptr @fld.str.926, i64 7 }, { ptr, i64 } { ptr @fld.str.927, i64 9 }] -@str.929 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.930 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 -@str.931 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.932 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.933 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.934 = private constant [5 x i8] c"data\00" -@field_names.935 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.934, i64 4 }] -@str.936 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.937 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 -@str.938 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.939 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.940 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.941 = private constant [2 x i8] c"x\00" -@fld.str.942 = private constant [2 x i8] c"y\00" -@field_names.943 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.941, i64 1 }, { ptr, i64 } { ptr @fld.str.942, i64 1 }] -@str.944 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.945 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 -@str.946 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.947 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.948 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.949 = private constant [2 x i8] c"x\00" -@fld.str.950 = private constant [2 x i8] c"y\00" -@field_names.951 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.949, i64 1 }, { ptr, i64 } { ptr @fld.str.950, i64 1 }] -@str.952 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.953 = private unnamed_addr constant [8 x i8] c"Counter\00", align 1 -@str.954 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.955 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.956 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.957 = private constant [4 x i8] c"ctx\00" -@fld.str.958 = private constant [9 x i8] c"__vtable\00" -@field_names.959 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.957, i64 3 }, { ptr, i64 } { ptr @fld.str.958, i64 8 }] -@str.960 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.961 = private unnamed_addr constant [18 x i8] c"__Counter__Vtable\00", align 1 -@str.962 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.963 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.964 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.965 = private constant [4 x i8] c"inc\00" -@fld.str.966 = private constant [4 x i8] c"get\00" -@field_names.967 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.965, i64 3 }, { ptr, i64 } { ptr @fld.str.966, i64 3 }] -@str.968 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.969 = private unnamed_addr constant [9 x i8] c"Summable\00", align 1 -@str.970 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.971 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.972 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.973 = private constant [4 x i8] c"ctx\00" -@fld.str.974 = private constant [9 x i8] c"__vtable\00" -@field_names.975 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.973, i64 3 }, { ptr, i64 } { ptr @fld.str.974, i64 8 }] -@str.976 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.977 = private unnamed_addr constant [19 x i8] c"__Summable__Vtable\00", align 1 -@str.978 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.979 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.980 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.981 = private constant [4 x i8] c"sum\00" -@field_names.982 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.981, i64 3 }] -@str.983 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.984 = private unnamed_addr constant [14 x i8] c"SimpleCounter\00", align 1 -@str.985 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.986 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.987 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.988 = private constant [4 x i8] c"val\00" -@field_names.989 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.988, i64 3 }] -@str.990 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.991 = private unnamed_addr constant [6 x i8] c"Adder\00", align 1 -@str.992 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.993 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.994 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.995 = private constant [4 x i8] c"ctx\00" -@fld.str.996 = private constant [4 x i8] c"add\00" -@fld.str.997 = private constant [6 x i8] c"value\00" -@field_names.998 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.995, i64 3 }, { ptr, i64 } { ptr @fld.str.996, i64 3 }, { ptr, i64 } { ptr @fld.str.997, i64 5 }] -@str.999 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.1000 = private unnamed_addr constant [12 x i8] c"Accumulator\00", align 1 -@str.1001 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.1002 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.1003 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.1004 = private constant [6 x i8] c"total\00" -@field_names.1005 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1004, i64 5 }] -@str.1006 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.1007 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.1008 = private constant [5 x i8] c"read\00" -@fld.str.1009 = private constant [6 x i8] c"write\00" -@fld.str.1010 = private constant [7 x i8] c"append\00" -@fld.str.1011 = private constant [11 x i8] c"read_write\00" -@field_names.1012 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1008, i64 4 }, { ptr, i64 } { ptr @fld.str.1009, i64 5 }, { ptr, i64 } { ptr @fld.str.1010, i64 6 }, { ptr, i64 } { ptr @fld.str.1011, i64 10 }] -@str.1013 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.1014 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.1015 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.1016 = private constant [4 x i8] c"set\00" -@fld.str.1017 = private constant [8 x i8] c"current\00" -@fld.str.1018 = private constant [4 x i8] c"end\00" -@field_names.1019 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1016, i64 3 }, { ptr, i64 } { ptr @fld.str.1017, i64 7 }, { ptr, i64 } { ptr @fld.str.1018, i64 3 }] -@str.1020 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.1021 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.1022 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.1023 = private constant [6 x i8] c"null_\00" -@fld.str.1024 = private constant [6 x i8] c"bool_\00" -@fld.str.1025 = private constant [5 x i8] c"int_\00" -@fld.str.1026 = private constant [4 x i8] c"str\00" -@fld.str.1027 = private constant [6 x i8] c"array\00" -@fld.str.1028 = private constant [7 x i8] c"object\00" -@field_names.1029 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1023, i64 5 }, { ptr, i64 } { ptr @fld.str.1024, i64 5 }, { ptr, i64 } { ptr @fld.str.1025, i64 4 }, { ptr, i64 } { ptr @fld.str.1026, i64 3 }, { ptr, i64 } { ptr @fld.str.1027, i64 5 }, { ptr, i64 } { ptr @fld.str.1028, i64 6 }] -@str.1030 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.1031 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.1032 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.1033 = private constant [6 x i8] c"macos\00" -@fld.str.1034 = private constant [6 x i8] c"linux\00" -@fld.str.1035 = private constant [8 x i8] c"windows\00" -@fld.str.1036 = private constant [5 x i8] c"wasm\00" -@fld.str.1037 = private constant [4 x i8] c"ios\00" -@fld.str.1038 = private constant [8 x i8] c"android\00" -@fld.str.1039 = private constant [8 x i8] c"unknown\00" -@field_names.1040 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1033, i64 5 }, { ptr, i64 } { ptr @fld.str.1034, i64 5 }, { ptr, i64 } { ptr @fld.str.1035, i64 7 }, { ptr, i64 } { ptr @fld.str.1036, i64 4 }, { ptr, i64 } { ptr @fld.str.1037, i64 3 }, { ptr, i64 } { ptr @fld.str.1038, i64 7 }, { ptr, i64 } { ptr @fld.str.1039, i64 7 }] -@str.1041 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.1042 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.1043 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.1044 = private constant [8 x i8] c"aarch64\00" -@fld.str.1045 = private constant [7 x i8] c"x86_64\00" -@fld.str.1046 = private constant [7 x i8] c"wasm32\00" -@fld.str.1047 = private constant [7 x i8] c"wasm64\00" -@fld.str.1048 = private constant [8 x i8] c"unknown\00" -@field_names.1049 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1044, i64 7 }, { ptr, i64 } { ptr @fld.str.1045, i64 6 }, { ptr, i64 } { ptr @fld.str.1046, i64 6 }, { ptr, i64 } { ptr @fld.str.1047, i64 6 }, { ptr, i64 } { ptr @fld.str.1048, i64 7 }] -@str.1050 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.1051 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.1052 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1053 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1054 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1055 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1056 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1057 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1058 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1059 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1060 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1061 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1062 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1063 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1064 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1065 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1066 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1067 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1068 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1069 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1070 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1071 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1072 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1073 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1074 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1075 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1076 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1077 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1078 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1079 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1080 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1081 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1082 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1083 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1084 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1085 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.1086 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.1087 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.1088 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1089 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.1090 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1091 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1092 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.1093 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1094 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1095 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.1096 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1097 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1098 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.1099 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1100 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1101 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.1102 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1103 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1104 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.1105 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1106 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1107 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.1108 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1109 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1110 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.1111 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1112 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1113 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.1114 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1115 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1116 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.1117 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1118 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1119 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.1120 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1121 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1122 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.1123 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1124 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1125 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.1126 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1127 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1128 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.1129 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1130 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1131 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.1132 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1133 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1134 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.1135 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1136 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1137 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.1138 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1139 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1140 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.1141 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1142 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1143 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.1144 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1145 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1146 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.1147 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1148 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1149 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.1150 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1151 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1152 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.1153 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1154 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1155 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.1156 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1157 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1158 = private unnamed_addr constant [15 x i8] c"*SimpleCounter\00", align 1 -@str.1159 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1160 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1161 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 -@str.1162 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1163 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1164 = private unnamed_addr constant [13 x i8] c"*Accumulator\00", align 1 -@str.1165 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1166 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1167 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.1168 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1169 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1170 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.1171 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1172 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1173 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.1174 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1175 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1176 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.1177 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1178 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1179 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.1180 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1181 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1182 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.1183 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1184 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1185 = private unnamed_addr constant [9 x i8] c"*Counter\00", align 1 -@str.1186 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1187 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1188 = private unnamed_addr constant [16 x i8] c"**SimpleCounter\00", align 1 -@str.1189 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1190 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1191 = private unnamed_addr constant [19 x i8] c"*__Counter__Vtable\00", align 1 -@str.1192 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1193 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1194 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.1195 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1196 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1197 = private unnamed_addr constant [7 x i8] c"*Adder\00", align 1 -@str.1198 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1199 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1200 = private unnamed_addr constant [14 x i8] c"**Accumulator\00", align 1 -@str.1201 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.1202 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1203 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.721 = private constant [5 x i8] c"line\00" +@fld.str.722 = private constant [4 x i8] c"col\00" +@fld.str.723 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.721, i64 4 }, { ptr, i64 } { ptr @fld.str.722, i64 3 }, { ptr, i64 } { ptr @fld.str.723, i64 4 }] +@str.724 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.725 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.726 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.727 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.728 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.729 = private constant [4 x i8] c"ctx\00" +@fld.str.730 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.731 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.732 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.729, i64 3 }, { ptr, i64 } { ptr @fld.str.730, i64 11 }, { ptr, i64 } { ptr @fld.str.731, i64 13 }] +@str.733 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.734 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.735 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.736 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.737 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.738 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.739 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.740 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.741 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.742 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.743 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.744 = private constant [12 x i8] c"alloc_count\00" +@field_names.745 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.744, i64 11 }] +@str.746 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.747 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.748 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.749 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.750 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.751 = private constant [5 x i8] c"next\00" +@fld.str.752 = private constant [4 x i8] c"cap\00" +@field_names.753 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.751, i64 4 }, { ptr, i64 } { ptr @fld.str.752, i64 3 }] +@str.754 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.755 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.756 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.757 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.758 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.759 = private constant [6 x i8] c"first\00" +@fld.str.760 = private constant [10 x i8] c"end_index\00" +@fld.str.761 = private constant [7 x i8] c"parent\00" +@field_names.762 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.759, i64 5 }, { ptr, i64 } { ptr @fld.str.760, i64 9 }, { ptr, i64 } { ptr @fld.str.761, i64 6 }] +@str.763 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.764 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.765 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.766 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.767 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.768 = private constant [4 x i8] c"buf\00" +@fld.str.769 = private constant [4 x i8] c"len\00" +@fld.str.770 = private constant [4 x i8] c"pos\00" +@field_names.771 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.768, i64 3 }, { ptr, i64 } { ptr @fld.str.769, i64 3 }, { ptr, i64 } { ptr @fld.str.770, i64 3 }] +@str.772 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.773 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.774 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.775 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.776 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.777 = private constant [7 x i8] c"parent\00" +@fld.str.778 = private constant [12 x i8] c"alloc_count\00" +@fld.str.779 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.780 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.781 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.777, i64 6 }, { ptr, i64 } { ptr @fld.str.778, i64 11 }, { ptr, i64 } { ptr @fld.str.779, i64 13 }, { ptr, i64 } { ptr @fld.str.780, i64 17 }] +@str.782 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.783 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.784 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.785 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.786 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.787 = private constant [10 x i8] c"allocator\00" +@fld.str.788 = private constant [5 x i8] c"data\00" +@field_names.789 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.787, i64 9 }, { ptr, i64 } { ptr @fld.str.788, i64 4 }] +@str.790 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.791 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.792 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.793 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.794 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.795 = private constant [3 x i8] c"fd\00" +@field_names.796 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.795, i64 2 }] +@str.797 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.798 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.799 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.800 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.801 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.802 = private constant [5 x i8] c"file\00" +@fld.str.803 = private constant [5 x i8] c"line\00" +@fld.str.804 = private constant [4 x i8] c"col\00" +@fld.str.805 = private constant [5 x i8] c"func\00" +@fld.str.806 = private constant [10 x i8] c"line_text\00" +@field_names.807 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.802, i64 4 }, { ptr, i64 } { ptr @fld.str.803, i64 4 }, { ptr, i64 } { ptr @fld.str.804, i64 3 }, { ptr, i64 } { ptr @fld.str.805, i64 4 }, { ptr, i64 } { ptr @fld.str.806, i64 9 }] +@str.808 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.809 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.810 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.811 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.812 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.813 = private constant [10 x i8] c"exit_code\00" +@fld.str.814 = private constant [7 x i8] c"stdout\00" +@field_names.815 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.813, i64 9 }, { ptr, i64 } { ptr @fld.str.814, i64 6 }] +@str.816 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.817 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.818 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.819 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.820 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.821 = private constant [8 x i8] c"sin_len\00" +@fld.str.822 = private constant [11 x i8] c"sin_family\00" +@fld.str.823 = private constant [9 x i8] c"sin_port\00" +@fld.str.824 = private constant [9 x i8] c"sin_addr\00" +@fld.str.825 = private constant [9 x i8] c"sin_zero\00" +@field_names.826 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.821, i64 7 }, { ptr, i64 } { ptr @fld.str.822, i64 10 }, { ptr, i64 } { ptr @fld.str.823, i64 8 }, { ptr, i64 } { ptr @fld.str.824, i64 8 }, { ptr, i64 } { ptr @fld.str.825, i64 8 }] +@str.827 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.828 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.829 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.830 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.831 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.832 = private constant [6 x i8] c"items\00" +@fld.str.833 = private constant [4 x i8] c"len\00" +@fld.str.834 = private constant [4 x i8] c"cap\00" +@field_names.835 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.832, i64 5 }, { ptr, i64 } { ptr @fld.str.833, i64 3 }, { ptr, i64 } { ptr @fld.str.834, i64 3 }] +@str.836 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.837 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.838 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.839 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.840 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.841 = private constant [6 x i8] c"items\00" +@fld.str.842 = private constant [4 x i8] c"len\00" +@fld.str.843 = private constant [4 x i8] c"cap\00" +@field_names.844 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.841, i64 5 }, { ptr, i64 } { ptr @fld.str.842, i64 3 }, { ptr, i64 } { ptr @fld.str.843, i64 3 }] +@str.845 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.846 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.847 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.848 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.849 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.850 = private constant [4 x i8] c"key\00" +@fld.str.851 = private constant [4 x i8] c"val\00" +@field_names.852 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.850, i64 3 }, { ptr, i64 } { ptr @fld.str.851, i64 3 }] +@str.853 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.854 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.855 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.856 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.857 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.858 = private constant [4 x i8] c"dst\00" +@fld.str.859 = private constant [4 x i8] c"pos\00" +@fld.str.860 = private constant [5 x i8] c"file\00" +@field_names.861 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.858, i64 3 }, { ptr, i64 } { ptr @fld.str.859, i64 3 }, { ptr, i64 } { ptr @fld.str.860, i64 4 }] +@str.862 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.863 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.864 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.865 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.866 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.867 = private constant [4 x i8] c"src\00" +@fld.str.868 = private constant [4 x i8] c"pos\00" +@fld.str.869 = private constant [6 x i8] c"alloc\00" +@field_names.870 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.867, i64 3 }, { ptr, i64 } { ptr @fld.str.868, i64 3 }, { ptr, i64 } { ptr @fld.str.869, i64 5 }] +@str.871 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.872 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.873 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.874 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.875 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.876 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.877 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.878 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.879 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.880 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.881 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.882 = private constant [5 x i8] c"name\00" +@fld.str.883 = private constant [12 x i8] c"takes_value\00" +@fld.str.884 = private constant [9 x i8] c"required\00" +@field_names.885 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.882, i64 4 }, { ptr, i64 } { ptr @fld.str.883, i64 11 }, { ptr, i64 } { ptr @fld.str.884, i64 8 }] +@str.886 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.887 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.888 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.889 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.890 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.891 = private constant [6 x i8] c"group\00" +@fld.str.892 = private constant [8 x i8] c"command\00" +@fld.str.893 = private constant [6 x i8] c"flags\00" +@field_names.894 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.891, i64 5 }, { ptr, i64 } { ptr @fld.str.892, i64 7 }, { ptr, i64 } { ptr @fld.str.893, i64 5 }] +@str.895 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.896 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.897 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.898 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.899 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.900 = private constant [4 x i8] c"set\00" +@fld.str.901 = private constant [6 x i8] c"value\00" +@field_names.902 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.900, i64 3 }, { ptr, i64 } { ptr @fld.str.901, i64 5 }] +@str.903 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.904 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.905 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.906 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.907 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.908 = private constant [6 x i8] c"index\00" +@fld.str.909 = private constant [6 x i8] c"token\00" +@field_names.910 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.908, i64 5 }, { ptr, i64 } { ptr @fld.str.909, i64 5 }] +@str.911 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.912 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.913 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.914 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.915 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.916 = private constant [6 x i8] c"group\00" +@fld.str.917 = private constant [8 x i8] c"command\00" +@fld.str.918 = private constant [10 x i8] c"cmd_index\00" +@fld.str.919 = private constant [5 x i8] c"json\00" +@fld.str.920 = private constant [5 x i8] c"rest\00" +@fld.str.921 = private constant [5 x i8] c"spec\00" +@fld.str.922 = private constant [7 x i8] c"values\00" +@field_names.923 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.916, i64 5 }, { ptr, i64 } { ptr @fld.str.917, i64 7 }, { ptr, i64 } { ptr @fld.str.918, i64 9 }, { ptr, i64 } { ptr @fld.str.919, i64 4 }, { ptr, i64 } { ptr @fld.str.920, i64 4 }, { ptr, i64 } { ptr @fld.str.921, i64 4 }, { ptr, i64 } { ptr @fld.str.922, i64 6 }] +@str.924 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.925 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.926 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.927 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.928 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.929 = private constant [2 x i8] c"h\00" +@fld.str.930 = private constant [4 x i8] c"buf\00" +@fld.str.931 = private constant [8 x i8] c"buf_len\00" +@fld.str.932 = private constant [10 x i8] c"total_len\00" +@field_names.933 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.929, i64 1 }, { ptr, i64 } { ptr @fld.str.930, i64 3 }, { ptr, i64 } { ptr @fld.str.931, i64 7 }, { ptr, i64 } { ptr @fld.str.932, i64 9 }] +@str.934 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.935 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.936 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.937 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.938 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.939 = private constant [5 x i8] c"data\00" +@field_names.940 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.939, i64 4 }] +@str.941 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.942 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.943 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.944 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.945 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.946 = private constant [2 x i8] c"x\00" +@fld.str.947 = private constant [2 x i8] c"y\00" +@field_names.948 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.946, i64 1 }, { ptr, i64 } { ptr @fld.str.947, i64 1 }] +@str.949 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.950 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.951 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.952 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.953 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.954 = private constant [2 x i8] c"x\00" +@fld.str.955 = private constant [2 x i8] c"y\00" +@field_names.956 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.954, i64 1 }, { ptr, i64 } { ptr @fld.str.955, i64 1 }] +@str.957 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.958 = private unnamed_addr constant [8 x i8] c"Counter\00", align 1 +@str.959 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.960 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.961 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.962 = private constant [4 x i8] c"ctx\00" +@fld.str.963 = private constant [9 x i8] c"__vtable\00" +@field_names.964 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.962, i64 3 }, { ptr, i64 } { ptr @fld.str.963, i64 8 }] +@str.965 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.966 = private unnamed_addr constant [18 x i8] c"__Counter__Vtable\00", align 1 +@str.967 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.968 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.969 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.970 = private constant [4 x i8] c"inc\00" +@fld.str.971 = private constant [4 x i8] c"get\00" +@field_names.972 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.970, i64 3 }, { ptr, i64 } { ptr @fld.str.971, i64 3 }] +@str.973 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.974 = private unnamed_addr constant [9 x i8] c"Summable\00", align 1 +@str.975 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.976 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.977 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.978 = private constant [4 x i8] c"ctx\00" +@fld.str.979 = private constant [9 x i8] c"__vtable\00" +@field_names.980 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.978, i64 3 }, { ptr, i64 } { ptr @fld.str.979, i64 8 }] +@str.981 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.982 = private unnamed_addr constant [19 x i8] c"__Summable__Vtable\00", align 1 +@str.983 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.984 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.985 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.986 = private constant [4 x i8] c"sum\00" +@field_names.987 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.986, i64 3 }] +@str.988 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.989 = private unnamed_addr constant [14 x i8] c"SimpleCounter\00", align 1 +@str.990 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.991 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.992 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.993 = private constant [4 x i8] c"val\00" +@field_names.994 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.993, i64 3 }] +@str.995 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.996 = private unnamed_addr constant [6 x i8] c"Adder\00", align 1 +@str.997 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.998 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.999 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.1000 = private constant [4 x i8] c"ctx\00" +@fld.str.1001 = private constant [4 x i8] c"add\00" +@fld.str.1002 = private constant [6 x i8] c"value\00" +@field_names.1003 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1000, i64 3 }, { ptr, i64 } { ptr @fld.str.1001, i64 3 }, { ptr, i64 } { ptr @fld.str.1002, i64 5 }] +@str.1004 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.1005 = private unnamed_addr constant [12 x i8] c"Accumulator\00", align 1 +@str.1006 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.1007 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.1008 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.1009 = private constant [6 x i8] c"total\00" +@field_names.1010 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1009, i64 5 }] +@str.1011 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.1012 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1013 = private constant [5 x i8] c"read\00" +@fld.str.1014 = private constant [6 x i8] c"write\00" +@fld.str.1015 = private constant [7 x i8] c"append\00" +@fld.str.1016 = private constant [11 x i8] c"read_write\00" +@field_names.1017 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1013, i64 4 }, { ptr, i64 } { ptr @fld.str.1014, i64 5 }, { ptr, i64 } { ptr @fld.str.1015, i64 6 }, { ptr, i64 } { ptr @fld.str.1016, i64 10 }] +@str.1018 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1019 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1020 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1021 = private constant [4 x i8] c"set\00" +@fld.str.1022 = private constant [8 x i8] c"current\00" +@fld.str.1023 = private constant [4 x i8] c"end\00" +@field_names.1024 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1021, i64 3 }, { ptr, i64 } { ptr @fld.str.1022, i64 7 }, { ptr, i64 } { ptr @fld.str.1023, i64 3 }] +@str.1025 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1026 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1027 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1028 = private constant [6 x i8] c"null_\00" +@fld.str.1029 = private constant [6 x i8] c"bool_\00" +@fld.str.1030 = private constant [5 x i8] c"int_\00" +@fld.str.1031 = private constant [4 x i8] c"str\00" +@fld.str.1032 = private constant [6 x i8] c"array\00" +@fld.str.1033 = private constant [7 x i8] c"object\00" +@field_names.1034 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1028, i64 5 }, { ptr, i64 } { ptr @fld.str.1029, i64 5 }, { ptr, i64 } { ptr @fld.str.1030, i64 4 }, { ptr, i64 } { ptr @fld.str.1031, i64 3 }, { ptr, i64 } { ptr @fld.str.1032, i64 5 }, { ptr, i64 } { ptr @fld.str.1033, i64 6 }] +@str.1035 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1036 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1037 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1038 = private constant [6 x i8] c"macos\00" +@fld.str.1039 = private constant [6 x i8] c"linux\00" +@fld.str.1040 = private constant [8 x i8] c"windows\00" +@fld.str.1041 = private constant [5 x i8] c"wasm\00" +@fld.str.1042 = private constant [4 x i8] c"ios\00" +@fld.str.1043 = private constant [8 x i8] c"android\00" +@fld.str.1044 = private constant [8 x i8] c"unknown\00" +@field_names.1045 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1038, i64 5 }, { ptr, i64 } { ptr @fld.str.1039, i64 5 }, { ptr, i64 } { ptr @fld.str.1040, i64 7 }, { ptr, i64 } { ptr @fld.str.1041, i64 4 }, { ptr, i64 } { ptr @fld.str.1042, i64 3 }, { ptr, i64 } { ptr @fld.str.1043, i64 7 }, { ptr, i64 } { ptr @fld.str.1044, i64 7 }] +@str.1046 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1047 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1048 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1049 = private constant [8 x i8] c"aarch64\00" +@fld.str.1050 = private constant [7 x i8] c"x86_64\00" +@fld.str.1051 = private constant [7 x i8] c"wasm32\00" +@fld.str.1052 = private constant [7 x i8] c"wasm64\00" +@fld.str.1053 = private constant [8 x i8] c"unknown\00" +@field_names.1054 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1049, i64 7 }, { ptr, i64 } { ptr @fld.str.1050, i64 6 }, { ptr, i64 } { ptr @fld.str.1051, i64 6 }, { ptr, i64 } { ptr @fld.str.1052, i64 6 }, { ptr, i64 } { ptr @fld.str.1053, i64 7 }] +@str.1055 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1056 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1057 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1058 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1059 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1060 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1061 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1062 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1063 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1064 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1065 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1066 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1067 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1068 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1069 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1070 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1071 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1072 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1073 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1074 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1075 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1076 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1077 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1078 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1079 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1080 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1081 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1082 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1083 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1084 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1085 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1086 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1087 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1088 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1089 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1090 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1091 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1092 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1093 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1094 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.1095 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1096 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1097 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.1098 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1099 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1100 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.1101 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1102 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1103 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.1104 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1105 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1106 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.1107 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1108 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1109 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.1110 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1111 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1112 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.1113 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1114 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1115 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.1116 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1117 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1118 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.1119 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1120 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1121 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.1122 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1123 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1124 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.1125 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1126 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1127 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.1128 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1129 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1130 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.1131 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1132 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1133 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.1134 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1135 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1136 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.1137 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1138 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1139 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.1140 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1141 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1142 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.1143 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1144 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1145 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.1146 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1147 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1148 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.1149 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1150 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1151 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.1152 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1153 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1154 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.1155 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1156 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1157 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.1158 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1159 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1160 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.1161 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1162 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1163 = private unnamed_addr constant [15 x i8] c"*SimpleCounter\00", align 1 +@str.1164 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1165 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1166 = private unnamed_addr constant [7 x i8] c"*Point\00", align 1 +@str.1167 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1168 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1169 = private unnamed_addr constant [13 x i8] c"*Accumulator\00", align 1 +@str.1170 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1171 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1172 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.1173 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1174 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1175 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.1176 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1177 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1178 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.1179 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1180 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1181 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.1182 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1183 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1184 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.1185 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1186 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1187 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.1188 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1189 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1190 = private unnamed_addr constant [9 x i8] c"*Counter\00", align 1 +@str.1191 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1192 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1193 = private unnamed_addr constant [16 x i8] c"**SimpleCounter\00", align 1 +@str.1194 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1195 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1196 = private unnamed_addr constant [19 x i8] c"*__Counter__Vtable\00", align 1 +@str.1197 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1198 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1199 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.1200 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1201 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1202 = private unnamed_addr constant [7 x i8] c"*Adder\00", align 1 +@str.1203 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.1204 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.1205 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1205 = private unnamed_addr constant [14 x i8] c"**Accumulator\00", align 1 +@str.1206 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1207 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1208 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1209 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1210 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -761,6 +761,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -980,7 +983,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.466, i64 1 } + ret { ptr, i64 } { ptr @str.471, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1107,7 +1110,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.467, i64 4 }, %if.then.78 ], [ { ptr @str.468, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.472, i64 4 }, %if.then.78 ], [ { ptr @str.473, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1441,7 +1444,7 @@ entry: br i1 %icmp, label %if.then.442, label %if.merge.443 if.then.442: ; preds = %entry - ret { ptr, i64 } { ptr @str.469, i64 1 } + ret { ptr, i64 } { ptr @str.474, i64 1 } if.merge.443: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1591,7 +1594,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.470, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.475, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1617,9 +1620,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1671,9 +1674,9 @@ entry: i64 85, label %match.arm.48 i64 110, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1720,7 +1723,7 @@ match.merge.37: ; preds = %dispatch.merge.566, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.471, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.476, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1764,9 +1767,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1858,9 +1861,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.400 [ i64 18, label %dispatch.case.401 - i64 21, label %dispatch.case.402 - i64 23, label %dispatch.case.403 - i64 25, label %dispatch.case.404 + i64 22, label %dispatch.case.402 + i64 24, label %dispatch.case.403 + i64 26, label %dispatch.case.404 i64 28, label %dispatch.case.405 i64 29, label %dispatch.case.406 i64 31, label %dispatch.case.407 @@ -1965,7 +1968,7 @@ dispatch.merge.94: ; preds = %dispatch.case.130, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.673, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.678, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1979,32 +1982,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2254,7 +2257,7 @@ dispatch.merge.306: ; preds = %dispatch.case.312, br label %match.merge.37 dispatch.default.307: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.674, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.679, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.306 dispatch.case.308: ; preds = %match.arm.44 @@ -2295,7 +2298,7 @@ dispatch.merge.323: ; preds = %dispatch.case.331, br label %match.merge.37 dispatch.default.324: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.675, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.680, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.323 dispatch.case.325: ; preds = %match.arm.47 @@ -2360,7 +2363,7 @@ dispatch.merge.367: ; preds = %dispatch.case.373, br label %match.merge.37 dispatch.default.368: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.676, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.681, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.367 dispatch.case.369: ; preds = %match.arm.48 @@ -2409,7 +2412,7 @@ dispatch.merge.399: ; preds = %dispatch.case.438, br label %match.merge.37 dispatch.default.400: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.677, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.682, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.399 dispatch.case.401: ; preds = %match.arm.49 @@ -2684,7 +2687,7 @@ dispatch.merge.566: ; preds = %dispatch.case.571, br label %match.merge.37 dispatch.default.567: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.678, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.683, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.566 dispatch.case.568: ; preds = %match.arm.50 @@ -2726,7 +2729,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.679, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.684, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2822,7 +2825,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2830,7 +2833,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2840,13 +2843,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2854,7 +2857,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2868,7 +2871,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2876,7 +2879,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2887,7 +2890,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2944,7 +2947,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2952,7 +2955,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2963,7 +2966,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2983,7 +2986,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2991,7 +2994,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, 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 @@ -3002,7 +3005,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.698, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -3012,64 +3015,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3245,163 +3251,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3599,64 +3608,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3686,97 +3695,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3815,7 +3824,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3884,1024 +3893,1033 @@ declare { float, float } @Vec2.negate(ptr, { float, float }) #0 declare i1 @Vec2.equals(ptr, { float, float }, { float, float }) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind -declare void @assert.162(ptr, i1) #0 +declare void @assert.164(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.163(ptr) #0 +declare void @out.165(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.164(ptr, ptr, i64) #0 +declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.165(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.166(ptr) #0 +declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.167(ptr, ptr, i64) #0 +declare i64 @GPA.init.169(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.169(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.170(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.171(ptr, ptr) #0 +declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.172(ptr, ptr) #0 +declare void @Arena.reset.174(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.173(ptr, ptr, i64) #0 +declare void @Arena.deinit.175(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.174(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.175(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.176(ptr, ptr) #0 +declare ptr @BufAlloc.init.178(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.177(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.178(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.179(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.180(ptr, ptr) #0 +declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.181(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.182(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.184(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.183(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @cstring.184(ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.185(ptr, i64) #0 +declare ptr @cstring.187(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.186(ptr, i64) #0 +declare ptr @int_to_string.188(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.187(ptr, i1) #0 +declare ptr @uint_to_string.189(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.188(ptr, double) #0 +declare ptr @bool_to_string.190(ptr, i1) #0 ; Function Attrs: nounwind -declare void @hex_group.189(ptr, ptr, i64, i64) #0 +declare ptr @float_to_string.191(ptr, double) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.190(ptr, i64) #0 +declare void @hex_group.192(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.191(ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @concat.192(ptr, ptr, ptr) #0 +declare ptr @int_to_hex_string.194(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.193(ptr, ptr, i64, i64) #0 +declare ptr @concat.195(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.194(ptr, ptr) #0 +declare ptr @substr.196(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.195(ptr, [2 x i64]) #0 +declare ptr @path_join.197(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.196(ptr, ptr) #0 +declare ptr @any_to_string.198(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.197(ptr, ptr, i64) #0 +declare ptr @build_format.199(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.198(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.199(ptr) #0 +declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.200(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.201(ptr, ptr, ptr) #0 +declare i64 @GPA.init.203(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.202(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.203(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.204(ptr, ptr) #0 +declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.205(ptr, ptr) #0 +declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.206(ptr, ptr, i64) #0 +declare void @Arena.reset.208(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.207(ptr, ptr, ptr) #0 +declare void @Arena.deinit.209(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.208(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.209(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.210(ptr, ptr, i64) #0 +declare ptr @BufAlloc.init.212(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.212(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.213(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.214(ptr, ptr) #0 +declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.215(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.216(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.218(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.217(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.218(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.219(ptr, i32, ...) #0 +declare ptr @escape.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.220(i32) #0 +declare void @log_emit.222(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.221(i32, ptr, i64) #0 +declare i32 @open.223(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.222(i32, i64, i32) #0 +declare i32 @close.224(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.223(ptr) #0 +declare i64 @read.225(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.224(ptr) #0 +declare i64 @lseek.226(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.225(ptr, i32) #0 +declare i32 @unlink.227(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.226(ptr, i32) #0 +declare i32 @rmdir.228(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.227(ptr, i32) #0 +declare i32 @mkdir.229(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.228(ptr, ptr) #0 +declare i32 @access.230(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.229(ptr, ptr) #0 +declare i32 @chmod.231(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.230(ptr, ptr) #0 +declare i32 @rename.232(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.231(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.233(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.232(ptr, ptr, ptr) #0 +declare i1 @File.close.234(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.233(ptr, ptr, i64, i64) #0 +declare i64 @File.read.235(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.234(ptr, i64) #0 +declare i64 @File.write.236(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.235(ptr, ptr, i64) #0 +declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.236(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.238(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.237(ptr, ptr, ptr) #0 +declare i64 @open_file.239(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.238(ptr, ptr, ptr) #0 +declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.239(ptr, ptr) #0 +declare i1 @write_file.241(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.240(ptr, ptr) #0 +declare i1 @append_file.242(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.241(ptr, ptr) #0 +declare i1 @exists.243(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.242(ptr, ptr) #0 +declare i1 @delete_file.244(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.243(ptr, ptr, i32) #0 +declare i1 @delete_dir.245(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.244(ptr, ptr, ptr) #0 +declare i1 @create_dir.246(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.245(ptr, ptr) #0 +declare i1 @set_mode.247(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.246(ptr, ptr, ptr) #0 +declare i1 @move.248(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.247(ptr, ptr) #0 +declare i1 @create_dir_all.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.248(ptr, ptr) #0 +declare i1 @copy_file.250(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.249(ptr, i32) #0 +declare ptr @basename.251(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.250() #0 +declare ptr @dirname.252(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.251() #0 +declare ptr @spaces.253(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.252(i32) #0 +declare i32 @sx_trace_len.254() #0 ; Function Attrs: nounwind -declare ptr @to_string.253(ptr) #0 +declare i32 @sx_trace_truncated.255() #0 ; Function Attrs: nounwind -declare void @print_current.254(ptr) #0 +declare i64 @sx_trace_frame_at.256(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.255(ptr) #0 +declare ptr @to_string.257(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.256(ptr, ptr) #0 +declare void @print_current.258(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.257(ptr) #0 +declare void @print_interpreter_frames.259(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.258(ptr, i64, i64, ptr) #0 +declare ptr @popen.260(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.259(ptr) #0 +declare i32 @pclose.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.260(ptr) #0 +declare i64 @fread.262(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.261(ptr) #0 +declare i32 @feof.263(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.262(ptr) #0 +declare ptr @getenv.264(ptr) #0 ; Function Attrs: nounwind -declare void @run.263(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.265(ptr) #0 ; Function Attrs: nounwind -declare void @env.264(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.266(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.265(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.266(i32) #0 +declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.267(ptr, i8, ptr) #0 +declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.268(ptr, i1, ptr, ptr) #0 +declare void @_exit.270(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.269(i32, i32, i32) #0 +declare void @exit.271(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.270(i32, i32, i32, ptr, i32) #0 +declare void @assert.272(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.271(i32, ptr, i32) #0 +declare i32 @socket.273(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.272(i32, i32) #0 +declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.273(i32, ptr, ptr) #0 +declare i32 @bind.275(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.274(i32, ptr, i64) #0 +declare i32 @listen.276(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.275(i32) #0 +declare i32 @accept.277(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.276(ptr, i64) #0 +declare i64 @read.278(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.277(ptr, ptr, i64) #0 +declare i32 @close.279(i32) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.278(ptr, ptr, ptr) #0 +declare i16 @htons.280(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.279(ptr) #0 +declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.280(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.281(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.282(ptr, ptr, i64) #0 +declare i64 @GPA.init.284(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.283(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.284(ptr, ptr) #0 +declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.285(ptr, ptr) #0 +declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.286(ptr, ptr, i64) #0 +declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.287(ptr, ptr, ptr) #0 +declare void @Arena.reset.289(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.288(ptr, ptr, i64) #0 +declare void @Arena.deinit.290(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.289(ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.290(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.291(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.init.293(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.292(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.reset.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.293(ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.294(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.297(ptr, i32, ...) #0 +declare void @TrackingAllocator.report.299(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.298(i32) #0 +declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @read.299(i32, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.300(i32, i64, i32) #0 +declare i32 @open.302(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.301(ptr) #0 +declare i32 @close.303(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.302(ptr) #0 +declare i64 @read.304(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.303(ptr, i32) #0 +declare i64 @lseek.305(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.304(ptr, i32) #0 +declare i32 @unlink.306(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.305(ptr, i32) #0 +declare i32 @rmdir.307(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.306(ptr, ptr) #0 +declare i32 @mkdir.308(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.307(ptr, ptr) #0 +declare i32 @access.309(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.308(ptr, ptr) #0 +declare i32 @chmod.310(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.309(ptr, ptr, ptr) #0 +declare i32 @rename.311(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.310(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.312(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.311(ptr, ptr, i64, i64) #0 +declare i1 @File.close.313(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.312(ptr, i64) #0 +declare i64 @File.read.314(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.313(ptr, ptr, i64) #0 +declare i64 @File.write.315(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.314(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.315(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.317(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.316(ptr, ptr, ptr) #0 +declare i64 @open_file.318(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.317(ptr, ptr) #0 +declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.318(ptr, ptr) #0 +declare i1 @write_file.320(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.319(ptr, ptr) #0 +declare i1 @append_file.321(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.320(ptr, ptr) #0 +declare i1 @exists.322(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.321(ptr, ptr, i32) #0 +declare i1 @delete_file.323(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.322(ptr, ptr, ptr) #0 +declare i1 @delete_dir.324(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.323(ptr, ptr) #0 +declare i1 @create_dir.325(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.324(ptr, ptr, ptr) #0 +declare i1 @set_mode.326(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.325(ptr, ptr) #0 +declare i1 @move.327(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.326(ptr, ptr) #0 +declare i1 @create_dir_all.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.327(ptr, ptr, ptr, ptr) #0 +declare i1 @copy_file.329(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.328(ptr, ptr, ptr) #0 +declare ptr @basename.330(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.329(ptr, ptr, ptr, ptr, ptr) #0 +declare ptr @dirname.331(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.330(ptr, ptr, ptr) #0 +declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.331(ptr, ptr, i8) #0 +declare void @Array.deinit.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.332(ptr, ptr, ptr) #0 +declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.333(ptr, ptr) #0 +declare void @Object.deinit.335(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.334(ptr, i64) #0 +declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.335(ptr, i8, ptr) #0 +declare i32 @Sink.put.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.336(ptr, ptr, ptr) #0 +declare i32 @Sink.flush.338(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_int.337(ptr, i64, ptr) #0 +declare i8 @hex_digit.339(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_value.338(ptr, ptr, ptr) #0 +declare i32 @write_u_escape.340(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.339(ptr, ptr, ptr) #0 +declare i32 @write_string.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.340(ptr, ptr, ptr) #0 +declare i32 @write_int.342(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.341(ptr, ptr, ptr) #0 +declare i32 @write_value.343(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.342(ptr, ptr, ptr, ptr) #0 +declare i32 @write_array.344(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.343(ptr, i8) #0 +declare i32 @write_object.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.344(ptr, i64, ptr) #0 +declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.345(ptr, ptr) #0 +declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.346(ptr, ptr, ptr) #0 +declare [2 x i64] @hex_value.348(ptr, i8) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.347(ptr, ptr, i64, i64) #0 +declare i64 @encode_utf8.349(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.348(ptr, ptr, i64, i64, ptr) #0 +declare void @Parser.skip_ws.350(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.349(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.350(ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.351(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.352(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.353(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.354(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.355(i64, ptr) #0 +declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.356(i64, ptr) #0 +declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.357(i64, ptr) #0 +declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.358(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.359(i64, ptr, ptr) #0 +declare void @BuildOptions.add_framework.361(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.360(i64) #0 +declare void @BuildOptions.set_output_path.362(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.361(i64, i64) #0 +declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.362(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.363(i64, ptr) #0 +declare i64 @BuildOptions.asset_dir_count.365(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.364(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.365(i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.366(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.367(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.368(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.370(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.369(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.370(i64) #0 +declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.371(i64) #0 +declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.372(i64) #0 +declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.373(i64) #0 +declare ptr @BuildOptions.bundle_path.375(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.374(i64) #0 +declare ptr @BuildOptions.bundle_id.376(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.375(i64) #0 +declare ptr @BuildOptions.codesign_identity.377(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.376(i64) #0 +declare ptr @BuildOptions.provisioning_profile.378(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.377(i64) #0 +declare ptr @BuildOptions.target_triple.379(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.378(i64) #0 +declare i1 @BuildOptions.is_macos.380(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.379(i64) #0 +declare i1 @BuildOptions.is_ios.381(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.380(i64) #0 +declare i1 @BuildOptions.is_ios_device.382(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.381(i64, i64) #0 +declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.382(i64) #0 +declare i1 @BuildOptions.is_android.384(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.383(i64, i64) #0 +declare i64 @BuildOptions.framework_count.385(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.384(i64, ptr) #0 +declare ptr @BuildOptions.framework_at.386(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.385(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.386(i64) #0 +declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.387(i64) #0 +declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.388(i64) #0 +declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.389(i64, i64) #0 +declare ptr @BuildOptions.manifest_path.391(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.390(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.392(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.391() #0 +declare i64 @BuildOptions.jni_main_count.393(i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.392(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.393() #0 +declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.394() #0 +declare i64 @build_options.396() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.395(i32) #0 +declare ptr @spaces.397(ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.396(ptr) #0 +declare i32 @sx_trace_len.398() #0 ; Function Attrs: nounwind -declare void @print_current.397(ptr) #0 +declare i32 @sx_trace_truncated.399() #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.398(ptr) #0 +declare i64 @sx_trace_frame_at.400(i32) #0 ; Function Attrs: nounwind -declare ptr @popen.399(ptr, ptr) #0 +declare ptr @to_string.401(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.400(ptr) #0 +declare void @print_current.402(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.401(ptr, i64, i64, ptr) #0 +declare void @print_interpreter_frames.403(ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.402(ptr) #0 +declare ptr @popen.404(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.403(ptr) #0 +declare i32 @pclose.405(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.404(ptr) #0 +declare i64 @fread.406(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @system.405(ptr) #0 +declare i32 @feof.407(ptr) #0 ; Function Attrs: nounwind -declare void @run.406(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare ptr @getenv.408(ptr) #0 ; Function Attrs: nounwind -declare void @env.407(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @strlen.409(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.408(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.410(ptr) #0 ; Function Attrs: nounwind -declare void @_exit.409(i32) #0 +declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.410(ptr, i8, ptr) #0 +declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.411(ptr, i1, ptr, ptr) #0 +declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.412() #0 +declare void @_exit.414(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.413() #0 +declare void @exit.415(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.414(ptr) #0 +declare void @assert.416(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_usage.415(ptr) #0 +declare ptr @_NSGetArgv.417() #0 ; Function Attrs: nounwind -declare i64 @os_argc.416(ptr) #0 +declare ptr @_NSGetArgc.418() #0 ; Function Attrs: nounwind -declare ptr @os_args.417(ptr, ptr) #0 +declare void @exit_ok.419(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.418(ptr, ptr, ptr) #0 +declare void @exit_usage.420(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.419(ptr, ptr, ptr) #0 +declare i64 @os_argc.421(ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.420(ptr, ptr) #0 +declare ptr @os_args.422(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.421(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.422(ptr, i32, ...) #0 +declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.423(i32) #0 +declare i1 @is_long_flag.425(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.424(i32, ptr, i64) #0 +declare void @parse.426(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @lseek.425(i32, i64, i32) #0 +declare i32 @open.427(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @unlink.426(ptr) #0 +declare i32 @close.428(i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.427(ptr) #0 +declare i64 @read.429(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @mkdir.428(ptr, i32) #0 +declare i64 @lseek.430(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @access.429(ptr, i32) #0 +declare i32 @unlink.431(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.430(ptr, i32) #0 +declare i32 @rmdir.432(ptr) #0 ; Function Attrs: nounwind -declare i32 @rename.431(ptr, ptr) #0 +declare i32 @mkdir.433(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.432(ptr, ptr) #0 +declare i32 @access.434(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.433(ptr, ptr) #0 +declare i32 @chmod.435(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @File.read.434(ptr, ptr, ptr) #0 +declare i32 @rename.436(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.435(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.437(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.436(ptr, ptr, i64, i64) #0 +declare i1 @File.close.438(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.437(ptr, i64) #0 +declare i64 @File.read.439(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.438(ptr, ptr, i64) #0 +declare i64 @File.write.440(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @read_file.439(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.440(ptr, ptr, ptr) #0 +declare i32 @mode_to_flags.442(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.441(ptr, ptr, ptr) #0 +declare i64 @open_file.443(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @exists.442(ptr, ptr) #0 +declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.443(ptr, ptr) #0 +declare i1 @write_file.445(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.444(ptr, ptr) #0 +declare i1 @append_file.446(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.445(ptr, ptr) #0 +declare i1 @exists.447(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.446(ptr, ptr, i32) #0 +declare i1 @delete_file.448(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.447(ptr, ptr, ptr) #0 +declare i1 @delete_dir.449(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.448(ptr, ptr) #0 +declare i1 @create_dir.450(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.449(ptr, ptr, ptr) #0 +declare i1 @set_mode.451(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare ptr @basename.450(ptr, ptr) #0 +declare i1 @move.452(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.451(ptr, ptr) #0 +declare i1 @create_dir_all.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.452(ptr, i64, i64) #0 +declare i1 @copy_file.454(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.453(ptr, i64) #0 +declare ptr @basename.455(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.454(ptr, i64) #0 +declare ptr @dirname.456(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.455(ptr, i64) #0 +declare i64 @rotr.457(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.456(ptr, i64) #0 +declare i64 @big_sigma0.458(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.457(ptr, ptr) #0 +declare i64 @big_sigma1.459(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.458(ptr, ptr, ptr) #0 +declare i64 @small_sigma0.460(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.459(ptr, ptr) #0 +declare i64 @small_sigma1.461(ptr, i64) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.460(ptr, i64) #0 +declare void @Sha256.process_block.462(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.461(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare void @Sha256.update.463(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.462(ptr, ptr) #0 +declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @sha256_file.463(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare i8 @nibble_hex.465(ptr, i64) #0 ; Function Attrs: nounwind -declare void @assert.464(ptr, i1) #0 +declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 + +; Function Attrs: nounwind +declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.469(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4916,7 +4934,7 @@ declare i32 @add(ptr, i32, i32) #0 declare i32 @mul(ptr, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @add.465(ptr, i32, i32) #0 +declare i32 @add.470(ptr, i32, i32) #0 ; Function Attrs: nounwind define internal void @SimpleCounter.inc(ptr %0, ptr %1) #0 { @@ -5078,14 +5096,14 @@ entry: define internal void @print__ct_sb446f8dda4e4d2e__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.694, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.699, i64 26 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.695, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.700, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 26) @@ -5101,7 +5119,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.696, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.701, i64 26 }) ret { ptr, i64 } %call } @@ -5149,7 +5167,7 @@ entry: define internal void @print__ct_sbdf493528d053170__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.697, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.702, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -5165,7 +5183,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.698, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.703, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -5193,7 +5211,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.699, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.704, i64 8 }) ret { ptr, i64 } %call } @@ -5215,7 +5233,7 @@ entry: define internal void @print__ct_s35bfc3f99c7ed027__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.700, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.705, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -5231,7 +5249,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.701, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.706, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -5259,7 +5277,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.702, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.707, i64 8 }) ret { ptr, i64 } %call } @@ -5293,7 +5311,7 @@ entry: define internal void @print__ct_s9619ba29713d8564__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.703, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.708, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -5309,7 +5327,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.704, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.709, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -5337,7 +5355,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_3(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.705, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.710, i64 8 }) ret { ptr, i64 } %call } @@ -5365,7 +5383,7 @@ entry: define internal void @print__ct_s299c24782c1d67ee__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.706, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.711, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -5381,7 +5399,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.707, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.712, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -5409,7 +5427,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_4(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.708, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.713, i64 8 }) ret { ptr, i64 } %call } @@ -5429,7 +5447,7 @@ entry: define internal void @print__ct_sf40ed4735476a9ee__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.709, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.714, i64 8 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -5445,7 +5463,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.710, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.715, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -5473,7 +5491,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_5(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.711, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.716, i64 8 }) ret { ptr, i64 } %call } @@ -5484,7 +5502,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 15 }, { ptr, i64 } { ptr @str.713, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 15 }, { ptr, i64 } { ptr @str.718, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5503,12 +5521,12 @@ while.body.132: ; preds = %while.hdr.131 while.exit.133: ; preds = %while.hdr.131 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.714, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, i64 1 }) ret { ptr, i64 } %callN if.then.134: ; preds = %while.body.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.715, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.720, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.135 @@ -5520,7 +5538,7 @@ if.merge.135: ; preds = %if.then.134, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.724, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5573,20 +5591,20 @@ fv.case24: ; preds = %if.merge.135 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 10 }, { ptr, i64 } { ptr @str.721, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 9 }, { ptr, i64 } { ptr @str.726, 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.136 -while.hdr.136: ; preds = %if.merge.140, %entry +while.hdr.136: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.137, label %while.exit.138 while.body.137: ; preds = %while.hdr.136 @@ -5596,224 +5614,24 @@ while.body.137: ; preds = %while.hdr.136 while.exit.138: ; preds = %while.hdr.136 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.722, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.727, i64 1 }) ret { ptr, i64 } %callN if.then.139: ; preds = %while.body.137 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.728, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.140 if.merge.140: ; preds = %if.then.139, %while.body.137 %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.724, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.732, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.725, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } { ptr @str.727, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.728, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.729, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.731, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.732, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.141 - -fv.default: ; preds = %if.merge.145 - br label %fv.merge - -fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 10 }, { ptr, i64 } { ptr @str.734, 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.146 - -while.hdr.146: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.147, label %while.exit.148 - -while.body.147: ; preds = %while.hdr.146 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.149, label %if.merge.150 - -while.exit.148: ; preds = %while.hdr.146 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.735, i64 1 }) - ret { ptr, i64 } %callN - -if.then.149: ; preds = %while.body.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.150 - -if.merge.150: ; preds = %if.then.149, %while.body.147 - %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.739, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -fv.case: ; preds = %if.merge.150 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 9 }, { ptr, i64 } { ptr @str.742, 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.151 - -while.hdr.151: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.152, label %while.exit.153 - -while.body.152: ; preds = %while.hdr.151 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.154, label %if.merge.155 - -while.exit.153: ; preds = %while.hdr.151 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.743, i64 1 }) - ret { ptr, i64 } %callN - -if.then.154: ; preds = %while.body.152 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.744, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.155 - -if.merge.155: ; preds = %if.then.154, %while.body.152 - %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.748, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.749, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.733, 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 @@ -5832,27 +5650,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.140 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.140 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 10 }, { ptr, i64 } { ptr @str.735, 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.141 + +while.hdr.141: ; preds = %if.merge.145, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.736, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.737, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.738, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.739, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.141 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 3 }, { ptr, i64 } { ptr @str.741, 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.146 + +while.hdr.146: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.147, label %while.exit.148 + +while.body.147: ; preds = %while.hdr.146 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.149, label %if.merge.150 + +while.exit.148: ; preds = %while.hdr.146 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.742, i64 1 }) + ret { ptr, i64 } %callN + +if.then.149: ; preds = %while.body.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.743, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.150 + +if.merge.150: ; preds = %if.then.149, %while.body.147 + %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.745, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.746, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.146 + +fv.default: ; preds = %if.merge.150 + br label %fv.merge + +fv.case: ; preds = %if.merge.150 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 10 }, { ptr, i64 } { ptr @str.748, 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.151 + +while.hdr.151: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.152, label %while.exit.153 + +while.body.152: ; preds = %while.hdr.151 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.154, label %if.merge.155 + +while.exit.153: ; preds = %while.hdr.151 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.749, i64 1 }) + ret { ptr, i64 } %callN + +if.then.154: ; preds = %while.body.152 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.750, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.155 + +if.merge.155: ; preds = %if.then.154, %while.body.152 + %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.753, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.754, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.151 fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.155 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -5862,7 +5880,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 5 }, { ptr, i64 } { ptr @str.751, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 5 }, { ptr, i64 } { ptr @str.756, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5881,24 +5899,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.752, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.757, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.753, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.758, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %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.757, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.762, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.758, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.763, 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 @@ -5925,7 +5943,7 @@ fv.default: ; preds = %if.merge.160 fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -5937,7 +5955,7 @@ fv.case20: ; preds = %if.merge.160 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -5946,7 +5964,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 8 }, { ptr, i64 } { ptr @str.760, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 8 }, { ptr, i64 } { ptr @str.765, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5965,24 +5983,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.761, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.766, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.762, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.767, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.766, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.771, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.767, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.772, 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 @@ -6029,7 +6047,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 17 }, { ptr, i64 } { ptr @str.769, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 17 }, { ptr, i64 } { ptr @str.774, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6048,24 +6066,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.770, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.775, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.771, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.776, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.776, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.781, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.777, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.782, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -6094,7 +6112,7 @@ fv.case: ; preds = %if.merge.170 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.170 @@ -6119,7 +6137,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 7 }, { ptr, i64 } { ptr @str.779, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 7 }, { ptr, i64 } { ptr @str.784, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6138,24 +6156,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.780, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.785, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.781, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.786, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %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.784, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.789, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.785, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.790, 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 @@ -6182,7 +6200,7 @@ fv.case: ; preds = %if.merge.175 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.175 @@ -6197,7 +6215,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 4 }, { ptr, i64 } { ptr @str.787, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 4 }, { ptr, i64 } { ptr @str.792, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6216,24 +6234,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.788, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.793, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.789, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.794, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.791, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.796, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.792, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.797, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -6270,7 +6288,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 10 }, { ptr, i64 } { ptr @str.794, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 10 }, { ptr, i64 } { ptr @str.799, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6289,24 +6307,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.795, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.800, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.796, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.801, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.802, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.807, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.803, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.808, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6372,7 +6390,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 13 }, { ptr, i64 } { ptr @str.805, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 13 }, { ptr, i64 } { ptr @str.810, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6391,24 +6409,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.806, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.811, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.807, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.812, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.810, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.815, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.811, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.816, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -6450,7 +6468,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.812, i64 8 }, { ptr, i64 } { ptr @str.813, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.817, i64 8 }, { ptr, i64 } { ptr @str.818, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6469,24 +6487,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.814, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.819, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.815, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.820, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.821, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.826, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.822, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.827, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -6547,7 +6565,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.823, i64 5 }, { ptr, i64 } { ptr @str.824, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.828, i64 5 }, { ptr, i64 } { ptr @str.829, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6566,24 +6584,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.825, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.830, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.826, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.831, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.830, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.835, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.831, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.836, 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 @@ -6629,7 +6647,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.832, i64 6 }, { ptr, i64 } { ptr @str.833, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.837, i64 6 }, { ptr, i64 } { ptr @str.838, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6648,24 +6666,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.834, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.839, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.835, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.840, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.839, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.844, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.840, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.845, 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 @@ -6713,7 +6731,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.841, i64 6 }, { ptr, i64 } { ptr @str.842, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.846, i64 6 }, { ptr, i64 } { ptr @str.847, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6732,24 +6750,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.843, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.848, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.844, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.849, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.847, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.852, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.848, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.853, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -6793,7 +6811,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.849, i64 4 }, { ptr, i64 } { ptr @str.850, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.854, i64 4 }, { ptr, i64 } { ptr @str.855, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6812,24 +6830,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.851, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.856, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.852, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.857, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.856, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.861, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.857, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.862, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -6879,7 +6897,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.858, i64 6 }, { ptr, i64 } { ptr @str.859, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.863, i64 6 }, { ptr, i64 } { ptr @str.864, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6898,24 +6916,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.860, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.865, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.861, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.866, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.865, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.870, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.866, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.871, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -6955,7 +6973,7 @@ fv.case20: ; preds = %if.merge.220 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -6964,7 +6982,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.867, i64 12 }, { ptr, i64 } { ptr @str.868, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.872, i64 12 }, { ptr, i64 } { ptr @str.873, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6983,24 +7001,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.869, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.874, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.870, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.871, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.876, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.872, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.877, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -7020,7 +7038,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.873, i64 8 }, { ptr, i64 } { ptr @str.874, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.878, i64 8 }, { ptr, i64 } { ptr @str.879, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7039,24 +7057,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.875, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.880, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.876, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.881, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.880, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.885, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.881, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.886, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -7108,7 +7126,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.882, i64 7 }, { ptr, i64 } { ptr @str.883, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.887, i64 7 }, { ptr, i64 } { ptr @str.888, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7127,24 +7145,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.884, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.889, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.885, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.890, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.889, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.894, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.890, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.895, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -7196,7 +7214,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.891, i64 9 }, { ptr, i64 } { ptr @str.892, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.896, i64 9 }, { ptr, i64 } { ptr @str.897, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7215,24 +7233,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.893, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.898, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.894, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.899, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %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.897, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.902, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.898, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.903, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -7275,7 +7293,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.899, i64 4 }, { ptr, i64 } { ptr @str.900, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.904, i64 4 }, { ptr, i64 } { ptr @str.905, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7294,24 +7312,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.901, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.906, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.902, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.907, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %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.905, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.910, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.906, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.911, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -7357,7 +7375,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.907, i64 6 }, { ptr, i64 } { ptr @str.908, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.912, i64 6 }, { ptr, i64 } { ptr @str.913, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7376,24 +7394,24 @@ while.body.247: ; preds = %while.hdr.246 while.exit.248: ; preds = %while.hdr.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.909, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.914, i64 1 }) ret { ptr, i64 } %callN if.then.249: ; preds = %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.910, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.915, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.250 if.merge.250: ; preds = %if.then.249, %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.918, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.923, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.919, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.924, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -7475,7 +7493,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.920, i64 6 }, { ptr, i64 } { ptr @str.921, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.925, i64 6 }, { ptr, i64 } { ptr @str.926, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7494,24 +7512,24 @@ while.body.252: ; preds = %while.hdr.251 while.exit.253: ; preds = %while.hdr.251 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.922, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.927, i64 1 }) ret { ptr, i64 } %callN if.then.254: ; preds = %while.body.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.923, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.928, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.255 if.merge.255: ; preds = %if.then.254, %while.body.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.928, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.933, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.929, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.934, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -7567,7 +7585,7 @@ entry: %alloca = alloca { [16 x float] }, align 8 %ba.tmp = alloca [16 x float], align 4 store { [16 x float] } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.930, i64 4 }, { ptr, i64 } { ptr @str.931, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.935, i64 4 }, { ptr, i64 } { ptr @str.936, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7586,24 +7604,24 @@ while.body.257: ; preds = %while.hdr.256 while.exit.258: ; preds = %while.hdr.256 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.932, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.937, i64 1 }) ret { ptr, i64 } %callN if.then.259: ; preds = %while.body.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.933, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.938, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 if.merge.260: ; preds = %if.then.259, %while.body.257 %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.935, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.940, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.936, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.941, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -7638,7 +7656,7 @@ define internal { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %1 entry: %alloca = alloca { float, float }, align 8 store { float, float } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.937, i64 4 }, { ptr, i64 } { ptr @str.938, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.942, i64 4 }, { ptr, i64 } { ptr @str.943, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7657,24 +7675,24 @@ while.body.262: ; preds = %while.hdr.261 while.exit.263: ; preds = %while.hdr.261 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.939, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.944, i64 1 }) ret { ptr, i64 } %callN if.then.264: ; preds = %while.body.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.940, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.945, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.265 if.merge.265: ; preds = %if.then.264, %while.body.262 %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.943, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.948, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.944, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.949, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7717,7 +7735,7 @@ define internal { ptr, i64 } @struct_to_string__Point(ptr %0, { i32, i32 } %1) # entry: %alloca = alloca { i32, i32 }, align 8 store { i32, i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.945, i64 5 }, { ptr, i64 } { ptr @str.946, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.950, i64 5 }, { ptr, i64 } { ptr @str.951, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7736,24 +7754,24 @@ while.body.267: ; preds = %while.hdr.266 while.exit.268: ; preds = %while.hdr.266 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.947, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.952, i64 1 }) ret { ptr, i64 } %callN if.then.269: ; preds = %while.body.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.948, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.953, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 if.merge.270: ; preds = %if.then.269, %while.body.267 %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.951, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.956, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.952, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.957, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7794,7 +7812,7 @@ define internal { ptr, i64 } @struct_to_string__Counter(ptr %0, { ptr, ptr } %1) entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.953, i64 7 }, { ptr, i64 } { ptr @str.954, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.958, i64 7 }, { ptr, i64 } { ptr @str.959, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7813,24 +7831,24 @@ while.body.272: ; preds = %while.hdr.271 while.exit.273: ; preds = %while.hdr.271 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.955, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.960, i64 1 }) ret { ptr, i64 } %callN if.then.274: ; preds = %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.956, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.961, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.275 if.merge.275: ; preds = %if.then.274, %while.body.272 %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.959, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.964, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.960, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.965, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -7871,7 +7889,7 @@ define internal { ptr, i64 } @struct_to_string____Counter__Vtable(ptr %0, { ptr, entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.961, i64 17 }, { ptr, i64 } { ptr @str.962, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.966, i64 17 }, { ptr, i64 } { ptr @str.967, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7890,24 +7908,24 @@ while.body.277: ; preds = %while.hdr.276 while.exit.278: ; preds = %while.hdr.276 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.963, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.968, i64 1 }) ret { ptr, i64 } %callN if.then.279: ; preds = %while.body.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.964, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.969, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 if.merge.280: ; preds = %if.then.279, %while.body.277 %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.967, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.972, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.968, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.973, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -7948,7 +7966,7 @@ define internal { ptr, i64 } @struct_to_string__Summable(ptr %0, { ptr, ptr } %1 entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.969, i64 8 }, { ptr, i64 } { ptr @str.970, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.974, i64 8 }, { ptr, i64 } { ptr @str.975, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7967,24 +7985,24 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.971, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.976, i64 1 }) ret { ptr, i64 } %callN if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.972, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.977, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 if.merge.285: ; preds = %if.then.284, %while.body.282 %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.975, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.980, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.976, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.981, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -8025,7 +8043,7 @@ define internal { ptr, i64 } @struct_to_string____Summable__Vtable(ptr %0, { ptr entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.977, i64 18 }, { ptr, i64 } { ptr @str.978, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.982, i64 18 }, { ptr, i64 } { ptr @str.983, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8044,24 +8062,24 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.979, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.984, i64 1 }) ret { ptr, i64 } %callN if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.980, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.985, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 if.merge.290: ; preds = %if.then.289, %while.body.287 %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.982, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.987, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.983, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.988, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -8095,7 +8113,7 @@ define internal { ptr, i64 } @struct_to_string__SimpleCounter(ptr %0, { i32 } %1 entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.984, i64 13 }, { ptr, i64 } { ptr @str.985, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.989, i64 13 }, { ptr, i64 } { ptr @str.990, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8114,24 +8132,24 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.986, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.991, i64 1 }) ret { ptr, i64 } %callN if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.987, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.992, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 if.merge.295: ; preds = %if.then.294, %while.body.292 %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.989, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.994, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.990, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -8165,7 +8183,7 @@ define internal { ptr, i64 } @struct_to_string__Adder(ptr %0, { ptr, ptr, ptr } entry: %alloca = alloca { ptr, ptr, ptr }, align 8 store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.991, i64 5 }, { ptr, i64 } { ptr @str.992, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.996, i64 5 }, { ptr, i64 } { ptr @str.997, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8184,24 +8202,24 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.993, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.998, i64 1 }) ret { ptr, i64 } %callN if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.994, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.999, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 if.merge.300: ; preds = %if.then.299, %while.body.297 %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.998, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.1003, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.999, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1004, 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 @@ -8249,7 +8267,7 @@ define internal { ptr, i64 } @struct_to_string__Accumulator(ptr %0, { i32 } %1) entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1000, i64 11 }, { ptr, i64 } { ptr @str.1001, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1005, i64 11 }, { ptr, i64 } { ptr @str.1006, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8268,24 +8286,24 @@ while.body.302: ; preds = %while.hdr.301 while.exit.303: ; preds = %while.hdr.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1002, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1007, i64 1 }) ret { ptr, i64 } %callN if.then.304: ; preds = %while.body.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1003, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1008, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 if.merge.305: ; preds = %if.then.304, %while.body.302 %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.1005, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.1010, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1006, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1011, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -8323,9 +8341,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.1012, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.1017, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1007, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1012, 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 @@ -8344,8 +8362,8 @@ entry: if.then.313: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1014, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1013, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1019, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1018, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.314 @@ -8364,9 +8382,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.1019, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.1024, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1015, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1020, 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 @@ -8385,8 +8403,8 @@ entry: if.then.315: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1021, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1020, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1026, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1025, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.316 @@ -8416,9 +8434,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.1029, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.1034, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1022, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1027, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -8435,8 +8453,8 @@ entry: if.then.317: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1031, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1030, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1036, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1035, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -8514,9 +8532,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.1040, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.1045, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1032, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1037, 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 @@ -8535,8 +8553,8 @@ entry: if.then.319: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1042, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1041, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1047, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1046, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.320 @@ -8555,9 +8573,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.1049, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.1054, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1043, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1048, 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 @@ -8576,8 +8594,8 @@ entry: if.then.321: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1051, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1050, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1056, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1055, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -8594,7 +8612,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1052, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1057, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -8611,12 +8629,12 @@ while.body.333: ; preds = %while.hdr.332 while.exit.334: ; preds = %while.hdr.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1053, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1058, i64 1 }) ret { ptr, i64 } %call if.then.335: ; preds = %while.body.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1054, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1059, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.336 @@ -8645,7 +8663,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1055, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1060, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.337 @@ -8662,12 +8680,12 @@ while.body.338: ; preds = %while.hdr.337 while.exit.339: ; preds = %while.hdr.337 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1056, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1061, i64 1 }) ret { ptr, i64 } %call if.then.340: ; preds = %while.body.338 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1057, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1062, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.341 @@ -8697,7 +8715,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1058, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1063, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.342 @@ -8714,12 +8732,12 @@ while.body.343: ; preds = %while.hdr.342 while.exit.344: ; preds = %while.hdr.342 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1059, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1064, i64 1 }) ret { ptr, i64 } %call if.then.345: ; preds = %while.body.343 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1060, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1065, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.346 @@ -8747,7 +8765,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1061, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1066, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -8764,12 +8782,12 @@ while.body.348: ; preds = %while.hdr.347 while.exit.349: ; preds = %while.hdr.347 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1062, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1067, i64 1 }) ret { ptr, i64 } %call if.then.350: ; preds = %while.body.348 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1063, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1068, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.351 @@ -8798,7 +8816,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1064, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1069, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8815,12 +8833,12 @@ while.body.353: ; preds = %while.hdr.352 while.exit.354: ; preds = %while.hdr.352 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1065, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1070, i64 1 }) ret { ptr, i64 } %call if.then.355: ; preds = %while.body.353 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1066, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1071, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.356 @@ -8848,7 +8866,7 @@ entry: %ig.tmp = alloca [16 x float], align 4 store [16 x float] %1, ptr %alloca, align 4 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1067, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1072, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.357 @@ -8865,12 +8883,12 @@ while.body.358: ; preds = %while.hdr.357 while.exit.359: ; preds = %while.hdr.357 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1068, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1073, i64 1 }) ret { ptr, i64 } %call if.then.360: ; preds = %while.body.358 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1069, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1074, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.361 @@ -8901,7 +8919,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1070, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1075, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.362 @@ -8918,12 +8936,12 @@ while.body.363: ; preds = %while.hdr.362 while.exit.364: ; preds = %while.hdr.362 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1071, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1076, i64 1 }) ret { ptr, i64 } %call if.then.365: ; preds = %while.body.363 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1072, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1077, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.366 @@ -8953,7 +8971,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1073, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1078, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.374 @@ -8972,12 +8990,12 @@ while.body.375: ; preds = %while.hdr.374 while.exit.376: ; preds = %while.hdr.374 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1074, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1079, i64 1 }) ret { ptr, i64 } %call if.then.377: ; preds = %while.body.375 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1075, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1080, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.378 @@ -9006,7 +9024,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1076, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1081, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.379 @@ -9025,12 +9043,12 @@ while.body.380: ; preds = %while.hdr.379 while.exit.381: ; preds = %while.hdr.379 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1077, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1082, i64 1 }) ret { ptr, i64 } %call if.then.382: ; preds = %while.body.380 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1078, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1083, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.383 @@ -9059,7 +9077,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1079, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1084, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.384 @@ -9078,12 +9096,12 @@ while.body.385: ; preds = %while.hdr.384 while.exit.386: ; preds = %while.hdr.384 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1080, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1085, i64 1 }) ret { ptr, i64 } %call if.then.387: ; preds = %while.body.385 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1081, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1086, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.388 @@ -9113,7 +9131,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1082, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1087, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.389 @@ -9132,12 +9150,12 @@ while.body.390: ; preds = %while.hdr.389 while.exit.391: ; preds = %while.hdr.389 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1083, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1088, i64 1 }) ret { ptr, i64 } %call if.then.392: ; preds = %while.body.390 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1084, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1089, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.393 @@ -9167,7 +9185,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.1085, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1090, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.394 @@ -9186,12 +9204,12 @@ while.body.395: ; preds = %while.hdr.394 while.exit.396: ; preds = %while.hdr.394 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1086, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1091, i64 1 }) ret { ptr, i64 } %call if.then.397: ; preds = %while.body.395 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1087, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1092, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.398 @@ -9233,12 +9251,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1090, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1089, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1095, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1094, i64 5 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.1088, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.1093, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -9261,12 +9279,12 @@ if.then.455: ; preds = %entry if.else.456: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1093, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1092, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1098, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1097, i64 11 }, { ptr, i64 } %callN) br label %if.merge.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.1091, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.1096, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -9289,12 +9307,12 @@ if.then.458: ; preds = %entry if.else.459: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1096, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1095, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1101, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1100, i64 4 }, { ptr, i64 } %callN) br label %if.merge.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.1094, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.1099, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -9317,12 +9335,12 @@ if.then.461: ; preds = %entry if.else.462: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1099, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1098, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1104, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1103, i64 11 }, { ptr, i64 } %callN) br label %if.merge.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.1097, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.1102, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -9345,12 +9363,12 @@ if.then.464: ; preds = %entry if.else.465: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1102, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1101, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1107, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1106, i64 6 }, { ptr, i64 } %callN) br label %if.merge.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.1100, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.1105, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -9372,12 +9390,12 @@ if.then.467: ; preds = %entry if.else.468: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1105, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1104, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1110, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1109, i64 5 }, { ptr, i64 } %callN) br label %if.merge.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.1103, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.1108, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -9400,12 +9418,12 @@ if.then.470: ; preds = %entry if.else.471: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1108, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1107, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1113, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1112, i64 9 }, { ptr, i64 } %callN) br label %if.merge.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.1106, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.1111, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -9428,12 +9446,12 @@ if.then.473: ; preds = %entry if.else.474: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1111, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1110, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1116, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1115, i64 18 }, { ptr, i64 } %callN) br label %if.merge.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.1109, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.1114, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -9456,12 +9474,12 @@ if.then.476: ; preds = %entry if.else.477: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1114, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1113, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1119, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1118, i64 5 }, { ptr, i64 } %callN) br label %if.merge.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.1112, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.1117, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -9484,12 +9502,12 @@ if.then.479: ; preds = %entry if.else.480: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1117, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1116, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1122, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1121, i64 3 }, { ptr, i64 } %callN) br label %if.merge.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.1115, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.1120, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -9512,12 +9530,12 @@ if.then.482: ; preds = %entry if.else.483: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1120, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1119, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1125, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1124, i64 4 }, { ptr, i64 } %callN) br label %if.merge.484 if.merge.484: ; preds = %if.else.483, %if.then.482 - %bp = phi { ptr, i64 } [ { ptr @str.1118, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.1123, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -9540,12 +9558,12 @@ if.then.485: ; preds = %entry if.else.486: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1123, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1122, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1128, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1127, i64 9 }, { ptr, i64 } %callN) br label %if.merge.487 if.merge.487: ; preds = %if.else.486, %if.then.485 - %bp = phi { ptr, i64 } [ { ptr @str.1121, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.1126, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -9568,12 +9586,12 @@ if.then.488: ; preds = %entry if.else.489: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1126, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1125, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1131, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1130, i64 4 }, { ptr, i64 } %callN) br label %if.merge.490 if.merge.490: ; preds = %if.else.489, %if.then.488 - %bp = phi { ptr, i64 } [ { ptr @str.1124, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.1129, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -9595,12 +9613,12 @@ if.then.491: ; preds = %entry if.else.492: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1129, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1128, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1134, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1133, i64 8 }, { ptr, i64 } %callN) br label %if.merge.493 if.merge.493: ; preds = %if.else.492, %if.then.491 - %bp = phi { ptr, i64 } [ { ptr @str.1127, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.1132, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -9623,12 +9641,12 @@ if.then.494: ; preds = %entry if.else.495: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1132, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1131, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1137, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1136, i64 6 }, { ptr, i64 } %callN) br label %if.merge.496 if.merge.496: ; preds = %if.else.495, %if.then.494 - %bp = phi { ptr, i64 } [ { ptr @str.1130, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.1135, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -9650,12 +9668,12 @@ if.then.497: ; preds = %entry if.else.498: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1135, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1134, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1140, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1139, i64 9 }, { ptr, i64 } %callN) br label %if.merge.499 if.merge.499: ; preds = %if.else.498, %if.then.497 - %bp = phi { ptr, i64 } [ { ptr @str.1133, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.1138, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -9678,12 +9696,12 @@ if.then.500: ; preds = %entry if.else.501: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1138, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1137, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1143, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1142, i64 7 }, { ptr, i64 } %callN) br label %if.merge.502 if.merge.502: ; preds = %if.else.501, %if.then.500 - %bp = phi { ptr, i64 } [ { ptr @str.1136, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.1141, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -9706,12 +9724,12 @@ if.then.503: ; preds = %entry if.else.504: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1141, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1140, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1146, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1145, i64 5 }, { ptr, i64 } %callN) br label %if.merge.505 if.merge.505: ; preds = %if.else.504, %if.then.503 - %bp = phi { ptr, i64 } [ { ptr @str.1139, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.1144, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -9734,12 +9752,12 @@ if.then.506: ; preds = %entry if.else.507: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1144, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1143, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1149, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1148, i64 7 }, { ptr, i64 } %callN) br label %if.merge.508 if.merge.508: ; preds = %if.else.507, %if.then.506 - %bp = phi { ptr, i64 } [ { ptr @str.1142, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.1147, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -9762,12 +9780,12 @@ if.then.509: ; preds = %entry if.else.510: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1147, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1146, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1152, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1151, i64 4 }, { ptr, i64 } %callN) br label %if.merge.511 if.merge.511: ; preds = %if.else.510, %if.then.509 - %bp = phi { ptr, i64 } [ { ptr @str.1145, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.1150, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -9790,12 +9808,12 @@ if.then.512: ; preds = %entry if.else.513: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1150, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1149, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1155, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1154, i64 7 }, { ptr, i64 } %callN) br label %if.merge.514 if.merge.514: ; preds = %if.else.513, %if.then.512 - %bp = phi { ptr, i64 } [ { ptr @str.1148, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.1153, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -9818,12 +9836,12 @@ if.then.515: ; preds = %entry if.else.516: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1153, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1152, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1158, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1157, i64 5 }, { ptr, i64 } %callN) br label %if.merge.517 if.merge.517: ; preds = %if.else.516, %if.then.515 - %bp = phi { ptr, i64 } [ { ptr @str.1151, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.1156, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -9846,12 +9864,12 @@ if.then.518: ; preds = %entry if.else.519: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1156, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1155, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1161, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1160, i64 7 }, { ptr, i64 } %callN) br label %if.merge.520 if.merge.520: ; preds = %if.else.519, %if.then.518 - %bp = phi { ptr, i64 } [ { ptr @str.1154, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.1159, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -9874,12 +9892,12 @@ if.then.521: ; preds = %entry if.else.522: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1159, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1158, i64 14 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1164, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1163, i64 14 }, { ptr, i64 } %callN) br label %if.merge.523 if.merge.523: ; preds = %if.else.522, %if.then.521 - %bp = phi { ptr, i64 } [ { ptr @str.1157, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.1162, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -9902,12 +9920,12 @@ if.then.524: ; preds = %entry if.else.525: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1162, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1161, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1167, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1166, i64 6 }, { ptr, i64 } %callN) br label %if.merge.526 if.merge.526: ; preds = %if.else.525, %if.then.524 - %bp = phi { ptr, i64 } [ { ptr @str.1160, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] + %bp = phi { ptr, i64 } [ { ptr @str.1165, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] ret { ptr, i64 } %bp } @@ -9930,12 +9948,12 @@ if.then.527: ; preds = %entry if.else.528: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1165, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1164, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1170, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1169, i64 12 }, { ptr, i64 } %callN) br label %if.merge.529 if.merge.529: ; preds = %if.else.528, %if.then.527 - %bp = phi { ptr, i64 } [ { ptr @str.1163, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] + %bp = phi { ptr, i64 } [ { ptr @str.1168, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] ret { ptr, i64 } %bp } @@ -9958,12 +9976,12 @@ if.then.530: ; preds = %entry if.else.531: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1168, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1167, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1173, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1172, i64 12 }, { ptr, i64 } %callN) br label %if.merge.532 if.merge.532: ; preds = %if.else.531, %if.then.530 - %bp = phi { ptr, i64 } [ { ptr @str.1166, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] + %bp = phi { ptr, i64 } [ { ptr @str.1171, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] ret { ptr, i64 } %bp } @@ -9986,12 +10004,12 @@ if.then.533: ; preds = %entry if.else.534: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1171, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1170, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1176, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1175, i64 6 }, { ptr, i64 } %callN) br label %if.merge.535 if.merge.535: ; preds = %if.else.534, %if.then.533 - %bp = phi { ptr, i64 } [ { ptr @str.1169, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] + %bp = phi { ptr, i64 } [ { ptr @str.1174, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] ret { ptr, i64 } %bp } @@ -10014,12 +10032,12 @@ if.then.536: ; preds = %entry if.else.537: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1174, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1173, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1179, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1178, i64 7 }, { ptr, i64 } %callN) br label %if.merge.538 if.merge.538: ; preds = %if.else.537, %if.then.536 - %bp = phi { ptr, i64 } [ { ptr @str.1172, i64 4 }, %if.then.536 ], [ %callN, %if.else.537 ] + %bp = phi { ptr, i64 } [ { ptr @str.1177, i64 4 }, %if.then.536 ], [ %callN, %if.else.537 ] ret { ptr, i64 } %bp } @@ -10042,12 +10060,12 @@ if.then.539: ; preds = %entry if.else.540: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1177, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1176, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1182, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1181, i64 4 }, { ptr, i64 } %callN) br label %if.merge.541 if.merge.541: ; preds = %if.else.540, %if.then.539 - %bp = phi { ptr, i64 } [ { ptr @str.1175, i64 4 }, %if.then.539 ], [ %callN, %if.else.540 ] + %bp = phi { ptr, i64 } [ { ptr @str.1180, i64 4 }, %if.then.539 ], [ %callN, %if.else.540 ] ret { ptr, i64 } %bp } @@ -10070,12 +10088,12 @@ if.then.542: ; preds = %entry if.else.543: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1180, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1179, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1185, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1184, i64 6 }, { ptr, i64 } %callN) br label %if.merge.544 if.merge.544: ; preds = %if.else.543, %if.then.542 - %bp = phi { ptr, i64 } [ { ptr @str.1178, i64 4 }, %if.then.542 ], [ %callN, %if.else.543 ] + %bp = phi { ptr, i64 } [ { ptr @str.1183, i64 4 }, %if.then.542 ], [ %callN, %if.else.543 ] ret { ptr, i64 } %bp } @@ -10098,12 +10116,12 @@ if.then.545: ; preds = %entry if.else.546: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1183, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1182, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1188, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1187, i64 5 }, { ptr, i64 } %callN) br label %if.merge.547 if.merge.547: ; preds = %if.else.546, %if.then.545 - %bp = phi { ptr, i64 } [ { ptr @str.1181, i64 4 }, %if.then.545 ], [ %callN, %if.else.546 ] + %bp = phi { ptr, i64 } [ { ptr @str.1186, i64 4 }, %if.then.545 ], [ %callN, %if.else.546 ] ret { ptr, i64 } %bp } @@ -10126,12 +10144,12 @@ if.then.548: ; preds = %entry if.else.549: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1186, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1185, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1191, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1190, i64 8 }, { ptr, i64 } %callN) br label %if.merge.550 if.merge.550: ; preds = %if.else.549, %if.then.548 - %bp = phi { ptr, i64 } [ { ptr @str.1184, i64 4 }, %if.then.548 ], [ %callN, %if.else.549 ] + %bp = phi { ptr, i64 } [ { ptr @str.1189, i64 4 }, %if.then.548 ], [ %callN, %if.else.549 ] ret { ptr, i64 } %bp } @@ -10154,12 +10172,12 @@ if.then.551: ; preds = %entry if.else.552: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1189, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1188, i64 15 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1194, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1193, i64 15 }, { ptr, i64 } %callN) br label %if.merge.553 if.merge.553: ; preds = %if.else.552, %if.then.551 - %bp = phi { ptr, i64 } [ { ptr @str.1187, i64 4 }, %if.then.551 ], [ %callN, %if.else.552 ] + %bp = phi { ptr, i64 } [ { ptr @str.1192, i64 4 }, %if.then.551 ], [ %callN, %if.else.552 ] ret { ptr, i64 } %bp } @@ -10182,12 +10200,12 @@ if.then.554: ; preds = %entry if.else.555: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1192, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1191, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1197, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1196, i64 18 }, { ptr, i64 } %callN) br label %if.merge.556 if.merge.556: ; preds = %if.else.555, %if.then.554 - %bp = phi { ptr, i64 } [ { ptr @str.1190, i64 4 }, %if.then.554 ], [ %callN, %if.else.555 ] + %bp = phi { ptr, i64 } [ { ptr @str.1195, i64 4 }, %if.then.554 ], [ %callN, %if.else.555 ] ret { ptr, i64 } %bp } @@ -10210,12 +10228,12 @@ if.then.557: ; preds = %entry if.else.558: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1195, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1194, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1200, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1199, i64 7 }, { ptr, i64 } %callN) br label %if.merge.559 if.merge.559: ; preds = %if.else.558, %if.then.557 - %bp = phi { ptr, i64 } [ { ptr @str.1193, i64 4 }, %if.then.557 ], [ %callN, %if.else.558 ] + %bp = phi { ptr, i64 } [ { ptr @str.1198, i64 4 }, %if.then.557 ], [ %callN, %if.else.558 ] ret { ptr, i64 } %bp } @@ -10238,12 +10256,12 @@ if.then.560: ; preds = %entry if.else.561: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1198, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1197, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1203, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1202, i64 6 }, { ptr, i64 } %callN) br label %if.merge.562 if.merge.562: ; preds = %if.else.561, %if.then.560 - %bp = phi { ptr, i64 } [ { ptr @str.1196, i64 4 }, %if.then.560 ], [ %callN, %if.else.561 ] + %bp = phi { ptr, i64 } [ { ptr @str.1201, i64 4 }, %if.then.560 ], [ %callN, %if.else.561 ] ret { ptr, i64 } %bp } @@ -10266,12 +10284,12 @@ if.then.563: ; preds = %entry if.else.564: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1201, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1200, i64 13 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1206, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1205, i64 13 }, { ptr, i64 } %callN) br label %if.merge.565 if.merge.565: ; preds = %if.else.564, %if.then.563 - %bp = phi { ptr, i64 } [ { ptr @str.1199, i64 4 }, %if.then.563 ], [ %callN, %if.else.564 ] + %bp = phi { ptr, i64 } [ { ptr @str.1204, i64 4 }, %if.then.563 ], [ %callN, %if.else.564 ] ret { ptr, i64 } %bp } @@ -10287,7 +10305,7 @@ entry: br i1 %lnot, label %if.then.572, label %if.merge.573 if.then.572: ; preds = %entry - ret { ptr, i64 } { ptr @str.1202, i64 4 } + ret { ptr, i64 } { ptr @str.1207, i64 4 } if.merge.573: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -10311,7 +10329,7 @@ entry: br i1 %lnot, label %if.then.574, label %if.merge.575 if.then.574: ; preds = %entry - ret { ptr, i64 } { ptr @str.1203, i64 4 } + ret { ptr, i64 } { ptr @str.1208, i64 4 } if.merge.575: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -10335,7 +10353,7 @@ entry: br i1 %lnot, label %if.then.576, label %if.merge.577 if.then.576: ; preds = %entry - ret { ptr, i64 } { ptr @str.1204, i64 4 } + ret { ptr, i64 } { ptr @str.1209, i64 4 } if.merge.577: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -10359,7 +10377,7 @@ entry: br i1 %lnot, label %if.then.578, label %if.merge.579 if.then.578: ; preds = %entry - ret { ptr, i64 } { ptr @str.1205, i64 4 } + ret { ptr, i64 } { ptr @str.1210, i64 4 } if.merge.579: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0507-packs-pack-mono-dedup.ir b/examples/expected/0507-packs-pack-mono-dedup.ir index 0117ceb..21ce9da 100644 --- a/examples/expected/0507-packs-pack-mono-dedup.ir +++ b/examples/expected/0507-packs-pack-mono-dedup.ir @@ -1,632 +1,632 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [168 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [6 x i8] c"[]Any\00" -@tn.str.239 = private constant [5 x i8] c"*Any\00" -@tn.str.240 = private constant [7 x i8] c"*[]Any\00" -@tn.str.241 = private constant [7 x i8] c"[1]Any\00" -@tn.str.242 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.243 = private constant [7 x i8] c"[3]Any\00" -@tn.str.244 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.245 = private constant [8 x i8] c"*string\00" -@tn.str.246 = private constant [6 x i8] c"*bool\00" -@tn.str.247 = private constant [7 x i8] c"[2]Any\00" -@tn.str.248 = private constant [8 x i8] c"*[2]Any\00" -@tn.str.249 = private constant [7 x i8] c"[5]Any\00" -@tn.str.250 = private constant [8 x i8] c"*[5]Any\00" -@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.252 = private constant [5 x i8] c"*f64\00" -@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.254 = private constant [11 x i8] c"*Allocator\00" -@tn.str.255 = private constant [9 x i8] c"*Context\00" -@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.258 = private constant [8 x i8] c"*Member\00" -@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.261 = private constant [9 x i8] c"*Command\00" -@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.265 = private constant [7 x i8] c"*Value\00" -@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.267 = private constant [14 x i8] c"*Architecture\00" -@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.272 = private constant [10 x i8] c"*[]string\00" -@tn.str.273 = private constant [6 x i8] c"*[]u8\00" -@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.275 = private constant [11 x i8] c"*[]Command\00" -@tn.str.276 = private constant [6 x i8] c"**GPA\00" -@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.278 = private constant [8 x i8] c"**Arena\00" -@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.282 = private constant [7 x i8] c"**File\00" -@tn.str.283 = private constant [5 x i8] c"**u8\00" -@tn.str.284 = private constant [6 x i8] c"**s32\00" -@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.286 = private constant [6 x i8] c"**u32\00" -@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.288 = private constant [8 x i8] c"**Array\00" -@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.290 = private constant [9 x i8] c"**Object\00" -@tn.str.291 = private constant [7 x i8] c"**Sink\00" -@tn.str.292 = private constant [9 x i8] c"**Parser\00" -@tn.str.293 = private constant [6 x i8] c"**s64\00" -@tn.str.294 = private constant [9 x i8] c"**Parsed\00" -@tn.str.295 = private constant [7 x i8] c"**Diag\00" -@tn.str.296 = private constant [9 x i8] c"**Sha256\00" -@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.298 = private constant [8 x i8] c"***void\00" -@tn.str.299 = private constant [6 x i8] c"**Any\00" -@tn.str.300 = private constant [8 x i8] c"**[]Any\00" -@tn.str.301 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.302 = private constant [9 x i8] c"**[3]Any\00" -@tn.str.303 = private constant [9 x i8] c"**string\00" -@tn.str.304 = private constant [7 x i8] c"**bool\00" -@tn.str.305 = private constant [9 x i8] c"**[2]Any\00" -@tn.str.306 = private constant [9 x i8] c"**[5]Any\00" -@tn.str.307 = private constant [7 x i8] c"*?File\00" -@tn.str.308 = private constant [9 x i8] c"*?string\00" -@tn.str.309 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.310 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [168 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 5 }, { ptr, i64 } { ptr @tn.str.239, i64 4 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 6 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 15 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }] -@str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [6 x i8] c"[]Any\00" +@tn.str.241 = private constant [5 x i8] c"*Any\00" +@tn.str.242 = private constant [7 x i8] c"*[]Any\00" +@tn.str.243 = private constant [7 x i8] c"[1]Any\00" +@tn.str.244 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.245 = private constant [7 x i8] c"[3]Any\00" +@tn.str.246 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.247 = private constant [8 x i8] c"*string\00" +@tn.str.248 = private constant [6 x i8] c"*bool\00" +@tn.str.249 = private constant [7 x i8] c"[2]Any\00" +@tn.str.250 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.251 = private constant [7 x i8] c"[5]Any\00" +@tn.str.252 = private constant [8 x i8] c"*[5]Any\00" +@tn.str.253 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.254 = private constant [5 x i8] c"*f64\00" +@tn.str.255 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.256 = private constant [11 x i8] c"*Allocator\00" +@tn.str.257 = private constant [9 x i8] c"*Context\00" +@tn.str.258 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.259 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.260 = private constant [8 x i8] c"*Member\00" +@tn.str.261 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.262 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.263 = private constant [9 x i8] c"*Command\00" +@tn.str.264 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.265 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.266 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.267 = private constant [7 x i8] c"*Value\00" +@tn.str.268 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.269 = private constant [14 x i8] c"*Architecture\00" +@tn.str.270 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.271 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.272 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.273 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.274 = private constant [10 x i8] c"*[]string\00" +@tn.str.275 = private constant [6 x i8] c"*[]u8\00" +@tn.str.276 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.277 = private constant [11 x i8] c"*[]Command\00" +@tn.str.278 = private constant [6 x i8] c"**GPA\00" +@tn.str.279 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.280 = private constant [8 x i8] c"**Arena\00" +@tn.str.281 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.282 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.283 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.284 = private constant [7 x i8] c"**File\00" +@tn.str.285 = private constant [5 x i8] c"**u8\00" +@tn.str.286 = private constant [6 x i8] c"**s32\00" +@tn.str.287 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.288 = private constant [6 x i8] c"**u32\00" +@tn.str.289 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.290 = private constant [8 x i8] c"**Array\00" +@tn.str.291 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.292 = private constant [9 x i8] c"**Object\00" +@tn.str.293 = private constant [7 x i8] c"**Sink\00" +@tn.str.294 = private constant [9 x i8] c"**Parser\00" +@tn.str.295 = private constant [6 x i8] c"**s64\00" +@tn.str.296 = private constant [9 x i8] c"**Parsed\00" +@tn.str.297 = private constant [7 x i8] c"**Diag\00" +@tn.str.298 = private constant [9 x i8] c"**Sha256\00" +@tn.str.299 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.300 = private constant [8 x i8] c"***void\00" +@tn.str.301 = private constant [6 x i8] c"**Any\00" +@tn.str.302 = private constant [8 x i8] c"**[]Any\00" +@tn.str.303 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.304 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.305 = private constant [9 x i8] c"**string\00" +@tn.str.306 = private constant [7 x i8] c"**bool\00" +@tn.str.307 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.308 = private constant [9 x i8] c"**[5]Any\00" +@tn.str.309 = private constant [7 x i8] c"*?File\00" +@tn.str.310 = private constant [9 x i8] c"*?string\00" +@tn.str.311 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.312 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [168 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 5 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 16 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 11 }, { ptr, i64 } { ptr @tn.str.259, i64 14 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 8 }, { ptr, i64 } { ptr @tn.str.264, i64 10 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 9 }, { ptr, i64 } { ptr @tn.str.267, i64 6 }, { ptr, i64 } { ptr @tn.str.268, i64 16 }, { ptr, i64 } { ptr @tn.str.269, i64 13 }, { ptr, i64 } { ptr @tn.str.270, i64 14 }, { ptr, i64 } { ptr @tn.str.271, i64 7 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 5 }, { ptr, i64 } { ptr @tn.str.276, i64 11 }, { ptr, i64 } { ptr @tn.str.277, i64 10 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 12 }, { ptr, i64 } { ptr @tn.str.280, i64 7 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 10 }, { ptr, i64 } { ptr @tn.str.283, i64 19 }, { ptr, i64 } { ptr @tn.str.284, i64 6 }, { ptr, i64 } { ptr @tn.str.285, i64 4 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 9 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 10 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 13 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 8 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 6 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }, { ptr, i64 } { ptr @tn.str.311, i64 15 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }] @str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.315 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.316 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.317 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.321 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.322 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.326 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.327 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.328 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.329 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.330 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.331 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.332 = private unnamed_addr constant [2 x i8] c"x\00", align 1 -@str.333 = private unnamed_addr constant [16 x i8] c"{} {} {} {} {}\0A\00", align 1 -@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.317 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.318 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.319 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.323 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.324 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.328 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.329 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.330 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.331 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.332 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.333 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.334 = private unnamed_addr constant [2 x i8] c"x\00", align 1 @str.335 = private unnamed_addr constant [16 x i8] c"{} {} {} {} {}\0A\00", align 1 -@str.336 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.337 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.338 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.337 = private unnamed_addr constant [16 x i8] c"{} {} {} {} {}\0A\00", align 1 +@str.338 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.339 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.340 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.340 = private constant [5 x i8] c"line\00" -@fld.str.341 = private constant [4 x i8] c"col\00" -@fld.str.342 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.340, i64 4 }, { ptr, i64 } { ptr @fld.str.341, i64 3 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }] -@str.343 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.344 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.346 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.348 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.350 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.354 = private constant [12 x i8] c"alloc_count\00" -@field_names.355 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 11 }] -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.361 = private constant [5 x i8] c"next\00" -@fld.str.362 = private constant [4 x i8] c"cap\00" -@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 4 }, { ptr, i64 } { ptr @fld.str.362, i64 3 }] -@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.365 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.367 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.369 = private constant [4 x i8] c"ctx\00" -@fld.str.370 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.371 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.372 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.369, i64 3 }, { ptr, i64 } { ptr @fld.str.370, i64 11 }, { ptr, i64 } { ptr @fld.str.371, i64 13 }] -@str.373 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.374 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.375 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.376 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.377 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.378 = private constant [6 x i8] c"first\00" -@fld.str.379 = private constant [10 x i8] c"end_index\00" -@fld.str.380 = private constant [7 x i8] c"parent\00" -@field_names.381 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.378, i64 5 }, { ptr, i64 } { ptr @fld.str.379, i64 9 }, { ptr, i64 } { ptr @fld.str.380, i64 6 }] -@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.383 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.387 = private constant [4 x i8] c"buf\00" -@fld.str.388 = private constant [4 x i8] c"len\00" -@fld.str.389 = private constant [4 x i8] c"pos\00" -@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }] -@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.392 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.396 = private constant [7 x i8] c"parent\00" -@fld.str.397 = private constant [12 x i8] c"alloc_count\00" -@fld.str.398 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.399 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.400 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 6 }, { ptr, i64 } { ptr @fld.str.397, i64 11 }, { ptr, i64 } { ptr @fld.str.398, i64 13 }, { ptr, i64 } { ptr @fld.str.399, i64 17 }] -@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.402 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.405 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.406 = private constant [10 x i8] c"allocator\00" -@fld.str.407 = private constant [5 x i8] c"data\00" -@field_names.408 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 9 }, { ptr, i64 } { ptr @fld.str.407, i64 4 }] -@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.410 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.414 = private constant [3 x i8] c"fd\00" -@field_names.415 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 2 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [5 x i8] c"file\00" -@fld.str.422 = private constant [5 x i8] c"line\00" -@fld.str.423 = private constant [4 x i8] c"col\00" -@fld.str.424 = private constant [5 x i8] c"func\00" -@fld.str.425 = private constant [10 x i8] c"line_text\00" -@field_names.426 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 9 }] -@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.428 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.432 = private constant [10 x i8] c"exit_code\00" -@fld.str.433 = private constant [7 x i8] c"stdout\00" -@field_names.434 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 9 }, { ptr, i64 } { ptr @fld.str.433, i64 6 }] -@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.436 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.439 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.440 = private constant [8 x i8] c"sin_len\00" -@fld.str.441 = private constant [11 x i8] c"sin_family\00" -@fld.str.442 = private constant [9 x i8] c"sin_port\00" -@fld.str.443 = private constant [9 x i8] c"sin_addr\00" -@fld.str.444 = private constant [9 x i8] c"sin_zero\00" -@field_names.445 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 7 }, { ptr, i64 } { ptr @fld.str.441, i64 10 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }] -@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.447 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.449 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.450 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.451 = private constant [6 x i8] c"items\00" -@fld.str.452 = private constant [4 x i8] c"len\00" -@fld.str.453 = private constant [4 x i8] c"cap\00" -@field_names.454 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 5 }, { ptr, i64 } { ptr @fld.str.452, i64 3 }, { ptr, i64 } { ptr @fld.str.453, i64 3 }] -@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.456 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.460 = private constant [6 x i8] c"items\00" -@fld.str.461 = private constant [4 x i8] c"len\00" -@fld.str.462 = private constant [4 x i8] c"cap\00" -@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] -@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.465 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.469 = private constant [4 x i8] c"key\00" -@fld.str.470 = private constant [4 x i8] c"val\00" -@field_names.471 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }] -@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.473 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.477 = private constant [4 x i8] c"dst\00" -@fld.str.478 = private constant [4 x i8] c"pos\00" -@fld.str.479 = private constant [5 x i8] c"file\00" -@field_names.480 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 4 }] -@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.482 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.486 = private constant [4 x i8] c"src\00" -@fld.str.487 = private constant [4 x i8] c"pos\00" -@fld.str.488 = private constant [6 x i8] c"alloc\00" -@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 5 }] -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.495 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.497 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.501 = private constant [5 x i8] c"name\00" -@fld.str.502 = private constant [12 x i8] c"takes_value\00" -@fld.str.503 = private constant [9 x i8] c"required\00" -@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 4 }, { ptr, i64 } { ptr @fld.str.502, i64 11 }, { ptr, i64 } { ptr @fld.str.503, i64 8 }] -@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.506 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.510 = private constant [6 x i8] c"group\00" -@fld.str.511 = private constant [8 x i8] c"command\00" -@fld.str.512 = private constant [6 x i8] c"flags\00" -@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 5 }, { ptr, i64 } { ptr @fld.str.511, i64 7 }, { ptr, i64 } { ptr @fld.str.512, i64 5 }] -@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.515 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.519 = private constant [4 x i8] c"set\00" -@fld.str.520 = private constant [6 x i8] c"value\00" -@field_names.521 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 3 }, { ptr, i64 } { ptr @fld.str.520, i64 5 }] -@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.523 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.525 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.526 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.527 = private constant [6 x i8] c"index\00" -@fld.str.528 = private constant [6 x i8] c"token\00" -@field_names.529 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 5 }, { ptr, i64 } { ptr @fld.str.528, i64 5 }] -@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.531 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.533 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.534 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.535 = private constant [6 x i8] c"group\00" -@fld.str.536 = private constant [8 x i8] c"command\00" -@fld.str.537 = private constant [10 x i8] c"cmd_index\00" -@fld.str.538 = private constant [5 x i8] c"json\00" -@fld.str.539 = private constant [5 x i8] c"rest\00" -@fld.str.540 = private constant [5 x i8] c"spec\00" -@fld.str.541 = private constant [7 x i8] c"values\00" -@field_names.542 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 5 }, { ptr, i64 } { ptr @fld.str.536, i64 7 }, { ptr, i64 } { ptr @fld.str.537, i64 9 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 6 }] -@str.543 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.544 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.547 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.548 = private constant [2 x i8] c"h\00" -@fld.str.549 = private constant [4 x i8] c"buf\00" -@fld.str.550 = private constant [8 x i8] c"buf_len\00" -@fld.str.551 = private constant [10 x i8] c"total_len\00" -@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 1 }, { ptr, i64 } { ptr @fld.str.549, i64 3 }, { ptr, i64 } { ptr @fld.str.550, i64 7 }, { ptr, i64 } { ptr @fld.str.551, i64 9 }] -@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.555 = private constant [5 x i8] c"read\00" -@fld.str.556 = private constant [6 x i8] c"write\00" -@fld.str.557 = private constant [7 x i8] c"append\00" -@fld.str.558 = private constant [11 x i8] c"read_write\00" -@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 5 }, { ptr, i64 } { ptr @fld.str.557, i64 6 }, { ptr, i64 } { ptr @fld.str.558, i64 10 }] -@str.560 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.563 = private constant [4 x i8] c"set\00" -@fld.str.564 = private constant [8 x i8] c"current\00" -@fld.str.565 = private constant [4 x i8] c"end\00" -@field_names.566 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 3 }, { ptr, i64 } { ptr @fld.str.564, i64 7 }, { ptr, i64 } { ptr @fld.str.565, i64 3 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [6 x i8] c"null_\00" -@fld.str.571 = private constant [6 x i8] c"bool_\00" -@fld.str.572 = private constant [5 x i8] c"int_\00" -@fld.str.573 = private constant [4 x i8] c"str\00" -@fld.str.574 = private constant [6 x i8] c"array\00" -@fld.str.575 = private constant [7 x i8] c"object\00" -@field_names.576 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 4 }, { ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 6 }] -@str.577 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.579 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.580 = private constant [6 x i8] c"macos\00" -@fld.str.581 = private constant [6 x i8] c"linux\00" -@fld.str.582 = private constant [8 x i8] c"windows\00" -@fld.str.583 = private constant [5 x i8] c"wasm\00" -@fld.str.584 = private constant [4 x i8] c"ios\00" -@fld.str.585 = private constant [8 x i8] c"android\00" -@fld.str.586 = private constant [8 x i8] c"unknown\00" -@field_names.587 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 7 }] -@str.588 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.591 = private constant [8 x i8] c"aarch64\00" -@fld.str.592 = private constant [7 x i8] c"x86_64\00" -@fld.str.593 = private constant [7 x i8] c"wasm32\00" -@fld.str.594 = private constant [7 x i8] c"wasm64\00" -@fld.str.595 = private constant [8 x i8] c"unknown\00" -@field_names.596 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 6 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] -@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.604 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.607 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.633 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.634 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.635 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.637 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.638 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.639 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.640 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.642 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.645 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.648 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.651 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.654 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.657 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.660 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.663 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.666 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.672 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.675 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.678 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.681 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.684 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.687 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.690 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.693 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.696 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.723 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.726 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 -@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.729 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.732 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.735 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 -@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.738 = private unnamed_addr constant [8 x i8] c"*[5]Any\00", align 1 -@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.342 = private constant [5 x i8] c"line\00" +@fld.str.343 = private constant [4 x i8] c"col\00" +@fld.str.344 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }, { ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 4 }] +@str.345 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.346 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.347 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.348 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.349 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.350 = private constant [4 x i8] c"ctx\00" +@fld.str.351 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.352 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.353 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.350, i64 3 }, { ptr, i64 } { ptr @fld.str.351, i64 11 }, { ptr, i64 } { ptr @fld.str.352, i64 13 }] +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.359 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [12 x i8] c"alloc_count\00" +@field_names.366 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 11 }] +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.372 = private constant [5 x i8] c"next\00" +@fld.str.373 = private constant [4 x i8] c"cap\00" +@field_names.374 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 4 }, { ptr, i64 } { ptr @fld.str.373, i64 3 }] +@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.376 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.380 = private constant [6 x i8] c"first\00" +@fld.str.381 = private constant [10 x i8] c"end_index\00" +@fld.str.382 = private constant [7 x i8] c"parent\00" +@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 5 }, { ptr, i64 } { ptr @fld.str.381, i64 9 }, { ptr, i64 } { ptr @fld.str.382, i64 6 }] +@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.385 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.389 = private constant [4 x i8] c"buf\00" +@fld.str.390 = private constant [4 x i8] c"len\00" +@fld.str.391 = private constant [4 x i8] c"pos\00" +@field_names.392 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 3 }, { ptr, i64 } { ptr @fld.str.391, i64 3 }] +@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.394 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.395 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.396 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.397 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.398 = private constant [7 x i8] c"parent\00" +@fld.str.399 = private constant [12 x i8] c"alloc_count\00" +@fld.str.400 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.401 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.402 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 6 }, { ptr, i64 } { ptr @fld.str.399, i64 11 }, { ptr, i64 } { ptr @fld.str.400, i64 13 }, { ptr, i64 } { ptr @fld.str.401, i64 17 }] +@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.404 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.408 = private constant [10 x i8] c"allocator\00" +@fld.str.409 = private constant [5 x i8] c"data\00" +@field_names.410 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 9 }, { ptr, i64 } { ptr @fld.str.409, i64 4 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [3 x i8] c"fd\00" +@field_names.417 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 2 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [5 x i8] c"file\00" +@fld.str.424 = private constant [5 x i8] c"line\00" +@fld.str.425 = private constant [4 x i8] c"col\00" +@fld.str.426 = private constant [5 x i8] c"func\00" +@fld.str.427 = private constant [10 x i8] c"line_text\00" +@field_names.428 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }, { ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 9 }] +@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.430 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.434 = private constant [10 x i8] c"exit_code\00" +@fld.str.435 = private constant [7 x i8] c"stdout\00" +@field_names.436 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 9 }, { ptr, i64 } { ptr @fld.str.435, i64 6 }] +@str.437 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.438 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.441 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.442 = private constant [8 x i8] c"sin_len\00" +@fld.str.443 = private constant [11 x i8] c"sin_family\00" +@fld.str.444 = private constant [9 x i8] c"sin_port\00" +@fld.str.445 = private constant [9 x i8] c"sin_addr\00" +@fld.str.446 = private constant [9 x i8] c"sin_zero\00" +@field_names.447 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 7 }, { ptr, i64 } { ptr @fld.str.443, i64 10 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }] +@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.449 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.453 = private constant [6 x i8] c"items\00" +@fld.str.454 = private constant [4 x i8] c"len\00" +@fld.str.455 = private constant [4 x i8] c"cap\00" +@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.462 = private constant [6 x i8] c"items\00" +@fld.str.463 = private constant [4 x i8] c"len\00" +@fld.str.464 = private constant [4 x i8] c"cap\00" +@field_names.465 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 5 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }, { ptr, i64 } { ptr @fld.str.464, i64 3 }] +@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.467 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.468 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.469 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.470 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.471 = private constant [4 x i8] c"key\00" +@fld.str.472 = private constant [4 x i8] c"val\00" +@field_names.473 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }] +@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.475 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.479 = private constant [4 x i8] c"dst\00" +@fld.str.480 = private constant [4 x i8] c"pos\00" +@fld.str.481 = private constant [5 x i8] c"file\00" +@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 4 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.488 = private constant [4 x i8] c"src\00" +@fld.str.489 = private constant [4 x i8] c"pos\00" +@fld.str.490 = private constant [6 x i8] c"alloc\00" +@field_names.491 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 5 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.497 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.499 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.503 = private constant [5 x i8] c"name\00" +@fld.str.504 = private constant [12 x i8] c"takes_value\00" +@fld.str.505 = private constant [9 x i8] c"required\00" +@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 4 }, { ptr, i64 } { ptr @fld.str.504, i64 11 }, { ptr, i64 } { ptr @fld.str.505, i64 8 }] +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.512 = private constant [6 x i8] c"group\00" +@fld.str.513 = private constant [8 x i8] c"command\00" +@fld.str.514 = private constant [6 x i8] c"flags\00" +@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 5 }, { ptr, i64 } { ptr @fld.str.513, i64 7 }, { ptr, i64 } { ptr @fld.str.514, i64 5 }] +@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.517 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.521 = private constant [4 x i8] c"set\00" +@fld.str.522 = private constant [6 x i8] c"value\00" +@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 5 }] +@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.525 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.529 = private constant [6 x i8] c"index\00" +@fld.str.530 = private constant [6 x i8] c"token\00" +@field_names.531 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 5 }, { ptr, i64 } { ptr @fld.str.530, i64 5 }] +@str.532 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.533 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.535 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.536 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.537 = private constant [6 x i8] c"group\00" +@fld.str.538 = private constant [8 x i8] c"command\00" +@fld.str.539 = private constant [10 x i8] c"cmd_index\00" +@fld.str.540 = private constant [5 x i8] c"json\00" +@fld.str.541 = private constant [5 x i8] c"rest\00" +@fld.str.542 = private constant [5 x i8] c"spec\00" +@fld.str.543 = private constant [7 x i8] c"values\00" +@field_names.544 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.537, i64 5 }, { ptr, i64 } { ptr @fld.str.538, i64 7 }, { ptr, i64 } { ptr @fld.str.539, i64 9 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 6 }] +@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.546 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.550 = private constant [2 x i8] c"h\00" +@fld.str.551 = private constant [4 x i8] c"buf\00" +@fld.str.552 = private constant [8 x i8] c"buf_len\00" +@fld.str.553 = private constant [10 x i8] c"total_len\00" +@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 1 }, { ptr, i64 } { ptr @fld.str.551, i64 3 }, { ptr, i64 } { ptr @fld.str.552, i64 7 }, { ptr, i64 } { ptr @fld.str.553, i64 9 }] +@str.555 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.557 = private constant [5 x i8] c"read\00" +@fld.str.558 = private constant [6 x i8] c"write\00" +@fld.str.559 = private constant [7 x i8] c"append\00" +@fld.str.560 = private constant [11 x i8] c"read_write\00" +@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 5 }, { ptr, i64 } { ptr @fld.str.559, i64 6 }, { ptr, i64 } { ptr @fld.str.560, i64 10 }] +@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.565 = private constant [4 x i8] c"set\00" +@fld.str.566 = private constant [8 x i8] c"current\00" +@fld.str.567 = private constant [4 x i8] c"end\00" +@field_names.568 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 7 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [6 x i8] c"null_\00" +@fld.str.573 = private constant [6 x i8] c"bool_\00" +@fld.str.574 = private constant [5 x i8] c"int_\00" +@fld.str.575 = private constant [4 x i8] c"str\00" +@fld.str.576 = private constant [6 x i8] c"array\00" +@fld.str.577 = private constant [7 x i8] c"object\00" +@field_names.578 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 4 }, { ptr, i64 } { ptr @fld.str.575, i64 3 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 6 }] +@str.579 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.581 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.582 = private constant [6 x i8] c"macos\00" +@fld.str.583 = private constant [6 x i8] c"linux\00" +@fld.str.584 = private constant [8 x i8] c"windows\00" +@fld.str.585 = private constant [5 x i8] c"wasm\00" +@fld.str.586 = private constant [4 x i8] c"ios\00" +@fld.str.587 = private constant [8 x i8] c"android\00" +@fld.str.588 = private constant [8 x i8] c"unknown\00" +@field_names.589 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.582, i64 5 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 4 }, { ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] +@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.593 = private constant [8 x i8] c"aarch64\00" +@fld.str.594 = private constant [7 x i8] c"x86_64\00" +@fld.str.595 = private constant [7 x i8] c"wasm32\00" +@fld.str.596 = private constant [7 x i8] c"wasm64\00" +@fld.str.597 = private constant [8 x i8] c"unknown\00" +@field_names.598 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 7 }] +@str.599 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.635 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.636 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.637 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.639 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.640 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.641 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.642 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.644 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.647 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.650 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.653 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.656 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.659 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.662 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.665 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.668 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.674 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.677 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.680 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.683 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.686 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.689 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.692 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.695 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.698 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.728 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.729 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.731 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.732 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.734 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.735 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.737 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 +@str.738 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.740 = private unnamed_addr constant [8 x i8] c"*[5]Any\00", align 1 +@str.741 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.742 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.745 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -639,6 +639,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -858,7 +861,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -985,7 +988,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1319,7 +1322,7 @@ entry: br i1 %icmp, label %if.then.389, label %if.merge.390 if.then.389: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.390: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1469,7 +1472,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1495,9 +1498,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1541,9 +1544,9 @@ entry: i64 85, label %match.arm.48 i64 95, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1585,7 +1588,7 @@ match.merge.37: ; preds = %dispatch.merge.498, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1629,9 +1632,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1715,9 +1718,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.352 [ i64 18, label %dispatch.case.353 - i64 21, label %dispatch.case.354 - i64 23, label %dispatch.case.355 - i64 25, label %dispatch.case.356 + i64 22, label %dispatch.case.354 + i64 24, label %dispatch.case.355 + i64 26, label %dispatch.case.356 i64 28, label %dispatch.case.357 i64 29, label %dispatch.case.358 i64 31, label %dispatch.case.359 @@ -1817,7 +1820,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1831,32 +1834,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2026,7 +2029,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2067,7 +2070,7 @@ dispatch.merge.263: ; preds = %dispatch.case.273, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2148,7 +2151,7 @@ dispatch.merge.319: ; preds = %dispatch.case.325, br label %match.merge.37 dispatch.default.320: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.319 dispatch.case.321: ; preds = %match.arm.48 @@ -2197,7 +2200,7 @@ dispatch.merge.351: ; preds = %dispatch.case.385, br label %match.merge.37 dispatch.default.352: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.351 dispatch.case.353: ; preds = %match.arm.49 @@ -2437,7 +2440,7 @@ dispatch.merge.498: ; preds = %dispatch.case.503, br label %match.merge.37 dispatch.default.499: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.318, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.498 dispatch.case.500: ; preds = %match.arm.50 @@ -2479,7 +2482,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.317, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.319, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2575,7 +2578,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2583,7 +2586,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2593,13 +2596,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2607,7 +2610,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2621,7 +2624,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2629,7 +2632,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2640,7 +2643,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2697,7 +2700,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2705,7 +2708,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2716,7 +2719,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2736,7 +2739,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2744,7 +2747,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, 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 @@ -2755,7 +2758,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2765,64 +2768,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2998,163 +3004,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3352,64 +3361,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3439,97 +3448,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3568,7 +3577,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3585,7 +3594,7 @@ entry: %callN = call i64 @count__pack_s64_s64_s64(ptr @__sx_default_context, i64 1, i64 2, i64 3) %allocaN = alloca i64, align 8 store i64 %callN, ptr %allocaN, align 8 - %callN = call i64 @count__pack_string_bool(ptr @__sx_default_context, { ptr, i64 } { ptr @str.332, i64 1 }, i1 true) + %callN = call i64 @count__pack_string_bool(ptr @__sx_default_context, { ptr, i64 } { ptr @str.334, i64 1 }, i1 true) %allocaN = alloca i64, align 8 store i64 %callN, ptr %allocaN, align 8 %load = load i64, ptr %alloca, align 8 @@ -3705,7 +3714,7 @@ entry: define internal void @print__ct_s9aced10c9b3e5318__pack_s64_s64_s64_s64_s64(ptr %0, i64 %1, i64 %2, i64 %3, i64 %4, i64 %5) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.335, i64 15 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3744,7 +3753,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 5, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ba.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -3810,7 +3819,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.335, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.337, i64 15 }) ret { ptr, i64 } %call } @@ -3821,7 +3830,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.336, i64 15 }, { ptr, i64 } { ptr @str.337, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.338, i64 15 }, { ptr, i64 } { ptr @str.339, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3840,12 +3849,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3857,7 +3866,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3910,20 +3919,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.344, i64 10 }, { ptr, i64 } { ptr @str.345, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.346, i64 9 }, { ptr, i64 } { ptr @str.347, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3933,224 +3942,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.348, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.353, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 3 }, { ptr, i64 } { ptr @str.351, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.355, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 10 }, { ptr, i64 } { ptr @str.358, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.363, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.365, i64 9 }, { ptr, i64 } { ptr @str.366, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.372, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, 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 @@ -4169,27 +3978,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 10 }, { ptr, i64 } { ptr @str.356, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.359, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 3 }, { ptr, i64 } { ptr @str.362, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.366, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 10 }, { ptr, i64 } { ptr @str.369, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.374, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4199,7 +4208,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.374, i64 5 }, { ptr, i64 } { ptr @str.375, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 5 }, { ptr, i64 } { ptr @str.377, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4218,24 +4227,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.383, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, 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 @@ -4262,7 +4271,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4274,7 +4283,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4283,7 +4292,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 8 }, { ptr, i64 } { ptr @str.384, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4302,24 +4311,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.390, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.392, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, 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 @@ -4366,7 +4375,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 17 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 17 }, { ptr, i64 } { ptr @str.395, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4385,24 +4394,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.400, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.402, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4431,7 +4440,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4456,7 +4465,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 7 }, { ptr, i64 } { ptr @str.403, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 7 }, { ptr, i64 } { ptr @str.405, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4475,24 +4484,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.410, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, 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 @@ -4519,7 +4528,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4534,7 +4543,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 4 }, { ptr, i64 } { ptr @str.411, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 4 }, { ptr, i64 } { ptr @str.413, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4553,24 +4562,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4607,7 +4616,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 10 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 10 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4626,24 +4635,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4709,7 +4718,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 13 }, { ptr, i64 } { ptr @str.429, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 13 }, { ptr, i64 } { ptr @str.431, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4728,24 +4737,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.434, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.436, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4787,7 +4796,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 8 }, { ptr, i64 } { ptr @str.437, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 8 }, { ptr, i64 } { ptr @str.439, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4806,24 +4815,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.445, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.447, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4884,7 +4893,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 5 }, { ptr, i64 } { ptr @str.448, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 5 }, { ptr, i64 } { ptr @str.450, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4903,24 +4912,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.456, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, 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 @@ -4966,7 +4975,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 6 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4985,24 +4994,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.463, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.465, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, 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 @@ -5050,7 +5059,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 6 }, { ptr, i64 } { ptr @str.468, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5069,24 +5078,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.471, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.473, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5130,7 +5139,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 4 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 4 }, { ptr, i64 } { ptr @str.476, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5149,24 +5158,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.482, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5216,7 +5225,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 6 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 6 }, { ptr, i64 } { ptr @str.485, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5235,24 +5244,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5292,7 +5301,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5301,7 +5310,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 12 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 12 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5320,24 +5329,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.495, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.497, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5357,7 +5366,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 8 }, { ptr, i64 } { ptr @str.498, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 8 }, { ptr, i64 } { ptr @str.500, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5376,24 +5385,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.506, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5445,7 +5454,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 7 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 7 }, { ptr, i64 } { ptr @str.509, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5464,24 +5473,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.513, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.515, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5533,7 +5542,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 9 }, { ptr, i64 } { ptr @str.516, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 9 }, { ptr, i64 } { ptr @str.518, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5552,24 +5561,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.521, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.523, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5612,7 +5621,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 4 }, { ptr, i64 } { ptr @str.524, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 4 }, { ptr, i64 } { ptr @str.526, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5631,24 +5640,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.529, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.531, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5694,7 +5703,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 6 }, { ptr, i64 } { ptr @str.532, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.533, i64 6 }, { ptr, i64 } { ptr @str.534, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5713,24 +5722,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.542, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.544, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5812,7 +5821,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.544, i64 6 }, { ptr, i64 } { ptr @str.545, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5831,24 +5840,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5907,9 +5916,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, 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 @@ -5928,8 +5937,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5948,9 +5957,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, 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 @@ -5969,8 +5978,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -6000,9 +6009,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.576, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.578, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6019,8 +6028,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -6098,9 +6107,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.587, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, 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 @@ -6119,8 +6128,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -6139,9 +6148,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, 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 @@ -6160,8 +6169,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6178,7 +6187,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.274 @@ -6195,12 +6204,12 @@ while.body.275: ; preds = %while.hdr.274 while.exit.276: ; preds = %while.hdr.274 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %call if.then.277: ; preds = %while.body.275 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.278 @@ -6229,7 +6238,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.279 @@ -6246,12 +6255,12 @@ while.body.280: ; preds = %while.hdr.279 while.exit.281: ; preds = %while.hdr.279 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) ret { ptr, i64 } %call if.then.282: ; preds = %while.body.280 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.283 @@ -6281,7 +6290,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.284 @@ -6298,12 +6307,12 @@ while.body.285: ; preds = %while.hdr.284 while.exit.286: ; preds = %while.hdr.284 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) ret { ptr, i64 } %call if.then.287: ; preds = %while.body.285 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.288 @@ -6331,7 +6340,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.289 @@ -6348,12 +6357,12 @@ while.body.290: ; preds = %while.hdr.289 while.exit.291: ; preds = %while.hdr.289 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) ret { ptr, i64 } %call if.then.292: ; preds = %while.body.290 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.293 @@ -6382,7 +6391,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.294 @@ -6399,12 +6408,12 @@ while.body.295: ; preds = %while.hdr.294 while.exit.296: ; preds = %while.hdr.294 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) ret { ptr, i64 } %call if.then.297: ; preds = %while.body.295 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.298 @@ -6433,7 +6442,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.299 @@ -6450,12 +6459,12 @@ while.body.300: ; preds = %while.hdr.299 while.exit.301: ; preds = %while.hdr.299 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) ret { ptr, i64 } %call if.then.302: ; preds = %while.body.300 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.303 @@ -6486,7 +6495,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.304 @@ -6503,12 +6512,12 @@ while.body.305: ; preds = %while.hdr.304 while.exit.306: ; preds = %while.hdr.304 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) ret { ptr, i64 } %call if.then.307: ; preds = %while.body.305 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.308 @@ -6539,7 +6548,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [2 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.309 @@ -6556,12 +6565,12 @@ while.body.310: ; preds = %while.hdr.309 while.exit.311: ; preds = %while.hdr.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) ret { ptr, i64 } %call if.then.312: ; preds = %while.body.310 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.313 @@ -6592,7 +6601,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [5 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6609,12 +6618,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6644,7 +6653,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.326 @@ -6663,12 +6672,12 @@ while.body.327: ; preds = %while.hdr.326 while.exit.328: ; preds = %while.hdr.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) ret { ptr, i64 } %call if.then.329: ; preds = %while.body.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.330 @@ -6697,7 +6706,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.631, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.331 @@ -6716,12 +6725,12 @@ while.body.332: ; preds = %while.hdr.331 while.exit.333: ; preds = %while.hdr.331 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) ret { ptr, i64 } %call if.then.334: ; preds = %while.body.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.335 @@ -6750,7 +6759,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.632, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.634, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.336 @@ -6769,12 +6778,12 @@ while.body.337: ; preds = %while.hdr.336 while.exit.338: ; preds = %while.hdr.336 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 1 }) ret { ptr, i64 } %call if.then.339: ; preds = %while.body.337 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.340 @@ -6804,7 +6813,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.635, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.637, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.341 @@ -6823,12 +6832,12 @@ while.body.342: ; preds = %while.hdr.341 while.exit.343: ; preds = %while.hdr.341 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 1 }) ret { ptr, i64 } %call if.then.344: ; preds = %while.body.342 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.345 @@ -6858,7 +6867,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.638, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.640, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.346 @@ -6877,12 +6886,12 @@ while.body.347: ; preds = %while.hdr.346 while.exit.348: ; preds = %while.hdr.346 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.641, i64 1 }) ret { ptr, i64 } %call if.then.349: ; preds = %while.body.347 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.350 @@ -6924,12 +6933,12 @@ if.then.386: ; preds = %entry if.else.387: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 5 }, { ptr, i64 } %callN) br label %if.merge.388 if.merge.388: ; preds = %if.else.387, %if.then.386 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] ret { ptr, i64 } %bp } @@ -6952,12 +6961,12 @@ if.then.402: ; preds = %entry if.else.403: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 11 }, { ptr, i64 } %callN) br label %if.merge.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6980,12 +6989,12 @@ if.then.405: ; preds = %entry if.else.406: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 4 }, { ptr, i64 } %callN) br label %if.merge.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -7008,12 +7017,12 @@ if.then.408: ; preds = %entry if.else.409: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 11 }, { ptr, i64 } %callN) br label %if.merge.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7036,12 +7045,12 @@ if.then.411: ; preds = %entry if.else.412: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 6 }, { ptr, i64 } %callN) br label %if.merge.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7063,12 +7072,12 @@ if.then.414: ; preds = %entry if.else.415: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 5 }, { ptr, i64 } %callN) br label %if.merge.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7091,12 +7100,12 @@ if.then.417: ; preds = %entry if.else.418: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 9 }, { ptr, i64 } %callN) br label %if.merge.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7119,12 +7128,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 18 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7147,12 +7156,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 5 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7175,12 +7184,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7203,12 +7212,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 4 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7231,12 +7240,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 9 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7259,12 +7268,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 4 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7286,12 +7295,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 8 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7314,12 +7323,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 6 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7341,12 +7350,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 9 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7369,12 +7378,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 7 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7397,12 +7406,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 5 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7425,12 +7434,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 7 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7453,12 +7462,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 4 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7481,12 +7490,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 7 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7509,12 +7518,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 5 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7537,12 +7546,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 7 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7565,12 +7574,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 12 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7593,12 +7602,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 6 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7621,12 +7630,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 4 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7649,12 +7658,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 6 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7677,12 +7686,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 7 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7705,12 +7714,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 7 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -7733,12 +7742,12 @@ if.then.486: ; preds = %entry if.else.487: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 7 }, { ptr, i64 } %callN) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -7761,12 +7770,12 @@ if.then.489: ; preds = %entry if.else.490: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 5 }, { ptr, i64 } %callN) br label %if.merge.491 if.merge.491: ; preds = %if.else.490, %if.then.489 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -7789,12 +7798,12 @@ if.then.492: ; preds = %entry if.else.493: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 7 }, { ptr, i64 } %callN) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -7817,12 +7826,12 @@ if.then.495: ; preds = %entry if.else.496: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 7 }, { ptr, i64 } %callN) br label %if.merge.497 if.merge.497: ; preds = %if.else.496, %if.then.495 - %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -7838,7 +7847,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.740, i64 4 } + ret { ptr, i64 } { ptr @str.742, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7862,7 +7871,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.741, i64 4 } + ret { ptr, i64 } { ptr @str.743, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7886,7 +7895,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.742, i64 4 } + ret { ptr, i64 } { ptr @str.744, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7910,7 +7919,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.743, i64 4 } + ret { ptr, i64 } { ptr @str.745, i64 4 } if.merge.511: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0513-packs-pack-mixed-comptime.ir b/examples/expected/0513-packs-pack-mixed-comptime.ir index fcd0aad..3a2224d 100644 --- a/examples/expected/0513-packs-pack-mixed-comptime.ir +++ b/examples/expected/0513-packs-pack-mixed-comptime.ir @@ -1,613 +1,613 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [162 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [6 x i8] c"[]Any\00" -@tn.str.239 = private constant [5 x i8] c"*Any\00" -@tn.str.240 = private constant [7 x i8] c"[3]Any\00" -@tn.str.241 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.242 = private constant [7 x i8] c"*[]Any\00" -@tn.str.243 = private constant [8 x i8] c"*string\00" -@tn.str.244 = private constant [7 x i8] c"[1]Any\00" -@tn.str.245 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.246 = private constant [6 x i8] c"*bool\00" -@tn.str.247 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.248 = private constant [5 x i8] c"*f64\00" -@tn.str.249 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.250 = private constant [11 x i8] c"*Allocator\00" -@tn.str.251 = private constant [9 x i8] c"*Context\00" -@tn.str.252 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.253 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.254 = private constant [8 x i8] c"*Member\00" -@tn.str.255 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.256 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.257 = private constant [9 x i8] c"*Command\00" -@tn.str.258 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.259 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.260 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.261 = private constant [7 x i8] c"*Value\00" -@tn.str.262 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.263 = private constant [14 x i8] c"*Architecture\00" -@tn.str.264 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.265 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.266 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.267 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.268 = private constant [10 x i8] c"*[]string\00" -@tn.str.269 = private constant [6 x i8] c"*[]u8\00" -@tn.str.270 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.271 = private constant [11 x i8] c"*[]Command\00" -@tn.str.272 = private constant [6 x i8] c"**GPA\00" -@tn.str.273 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.274 = private constant [8 x i8] c"**Arena\00" -@tn.str.275 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.276 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.277 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.278 = private constant [7 x i8] c"**File\00" -@tn.str.279 = private constant [5 x i8] c"**u8\00" -@tn.str.280 = private constant [6 x i8] c"**s32\00" -@tn.str.281 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.282 = private constant [6 x i8] c"**u32\00" -@tn.str.283 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.284 = private constant [8 x i8] c"**Array\00" -@tn.str.285 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.286 = private constant [9 x i8] c"**Object\00" -@tn.str.287 = private constant [7 x i8] c"**Sink\00" -@tn.str.288 = private constant [9 x i8] c"**Parser\00" -@tn.str.289 = private constant [6 x i8] c"**s64\00" -@tn.str.290 = private constant [9 x i8] c"**Parsed\00" -@tn.str.291 = private constant [7 x i8] c"**Diag\00" -@tn.str.292 = private constant [9 x i8] c"**Sha256\00" -@tn.str.293 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.294 = private constant [8 x i8] c"***void\00" -@tn.str.295 = private constant [6 x i8] c"**Any\00" -@tn.str.296 = private constant [9 x i8] c"**[3]Any\00" -@tn.str.297 = private constant [8 x i8] c"**[]Any\00" -@tn.str.298 = private constant [9 x i8] c"**string\00" -@tn.str.299 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.300 = private constant [7 x i8] c"**bool\00" -@tn.str.301 = private constant [7 x i8] c"*?File\00" -@tn.str.302 = private constant [9 x i8] c"*?string\00" -@tn.str.303 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.304 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 5 }, { ptr, i64 } { ptr @tn.str.239, i64 4 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 16 }, { ptr, i64 } { ptr @tn.str.250, i64 10 }, { ptr, i64 } { ptr @tn.str.251, i64 8 }, { ptr, i64 } { ptr @tn.str.252, i64 11 }, { ptr, i64 } { ptr @tn.str.253, i64 14 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 13 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 6 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 5 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 12 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 19 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 4 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 10 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 13 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 7 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 6 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 15 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }] -@str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [6 x i8] c"[]Any\00" +@tn.str.241 = private constant [5 x i8] c"*Any\00" +@tn.str.242 = private constant [7 x i8] c"[3]Any\00" +@tn.str.243 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.244 = private constant [7 x i8] c"*[]Any\00" +@tn.str.245 = private constant [8 x i8] c"*string\00" +@tn.str.246 = private constant [7 x i8] c"[1]Any\00" +@tn.str.247 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.248 = private constant [6 x i8] c"*bool\00" +@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.250 = private constant [5 x i8] c"*f64\00" +@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.252 = private constant [11 x i8] c"*Allocator\00" +@tn.str.253 = private constant [9 x i8] c"*Context\00" +@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.256 = private constant [8 x i8] c"*Member\00" +@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.259 = private constant [9 x i8] c"*Command\00" +@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.263 = private constant [7 x i8] c"*Value\00" +@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.265 = private constant [14 x i8] c"*Architecture\00" +@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.270 = private constant [10 x i8] c"*[]string\00" +@tn.str.271 = private constant [6 x i8] c"*[]u8\00" +@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.273 = private constant [11 x i8] c"*[]Command\00" +@tn.str.274 = private constant [6 x i8] c"**GPA\00" +@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.276 = private constant [8 x i8] c"**Arena\00" +@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.280 = private constant [7 x i8] c"**File\00" +@tn.str.281 = private constant [5 x i8] c"**u8\00" +@tn.str.282 = private constant [6 x i8] c"**s32\00" +@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.284 = private constant [6 x i8] c"**u32\00" +@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.286 = private constant [8 x i8] c"**Array\00" +@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.288 = private constant [9 x i8] c"**Object\00" +@tn.str.289 = private constant [7 x i8] c"**Sink\00" +@tn.str.290 = private constant [9 x i8] c"**Parser\00" +@tn.str.291 = private constant [6 x i8] c"**s64\00" +@tn.str.292 = private constant [9 x i8] c"**Parsed\00" +@tn.str.293 = private constant [7 x i8] c"**Diag\00" +@tn.str.294 = private constant [9 x i8] c"**Sha256\00" +@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.296 = private constant [8 x i8] c"***void\00" +@tn.str.297 = private constant [6 x i8] c"**Any\00" +@tn.str.298 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.299 = private constant [8 x i8] c"**[]Any\00" +@tn.str.300 = private constant [9 x i8] c"**string\00" +@tn.str.301 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.302 = private constant [7 x i8] c"**bool\00" +@tn.str.303 = private constant [7 x i8] c"*?File\00" +@tn.str.304 = private constant [9 x i8] c"*?string\00" +@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 5 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 5 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 7 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }] @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.311 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.312 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.313 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.314 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.315 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.316 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.326 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.313 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.314 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.315 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.316 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.317 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.318 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.328 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.329 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.330 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.331 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.332 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.331 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.332 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.333 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.334 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.333 = private constant [5 x i8] c"line\00" -@fld.str.334 = private constant [4 x i8] c"col\00" -@fld.str.335 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.333, i64 4 }, { ptr, i64 } { ptr @fld.str.334, i64 3 }, { ptr, i64 } { ptr @fld.str.335, i64 4 }] -@str.336 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.337 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.338 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.339 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.341 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.342 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.343 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.347 = private constant [12 x i8] c"alloc_count\00" -@field_names.348 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.347, i64 11 }] -@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.350 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.354 = private constant [5 x i8] c"next\00" -@fld.str.355 = private constant [4 x i8] c"cap\00" -@field_names.356 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 4 }, { ptr, i64 } { ptr @fld.str.355, i64 3 }] -@str.357 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.358 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.361 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.362 = private constant [4 x i8] c"ctx\00" -@fld.str.363 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.364 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.365 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.362, i64 3 }, { ptr, i64 } { ptr @fld.str.363, i64 11 }, { ptr, i64 } { ptr @fld.str.364, i64 13 }] -@str.366 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.367 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.368 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.369 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.371 = private constant [6 x i8] c"first\00" -@fld.str.372 = private constant [10 x i8] c"end_index\00" -@fld.str.373 = private constant [7 x i8] c"parent\00" -@field_names.374 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.371, i64 5 }, { ptr, i64 } { ptr @fld.str.372, i64 9 }, { ptr, i64 } { ptr @fld.str.373, i64 6 }] -@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.376 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.380 = private constant [4 x i8] c"buf\00" -@fld.str.381 = private constant [4 x i8] c"len\00" -@fld.str.382 = private constant [4 x i8] c"pos\00" -@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 3 }, { ptr, i64 } { ptr @fld.str.381, i64 3 }, { ptr, i64 } { ptr @fld.str.382, i64 3 }] -@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.385 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.389 = private constant [7 x i8] c"parent\00" -@fld.str.390 = private constant [12 x i8] c"alloc_count\00" -@fld.str.391 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.392 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.393 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 6 }, { ptr, i64 } { ptr @fld.str.390, i64 11 }, { ptr, i64 } { ptr @fld.str.391, i64 13 }, { ptr, i64 } { ptr @fld.str.392, i64 17 }] -@str.394 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.395 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.396 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.397 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.398 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.399 = private constant [10 x i8] c"allocator\00" -@fld.str.400 = private constant [5 x i8] c"data\00" -@field_names.401 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.399, i64 9 }, { ptr, i64 } { ptr @fld.str.400, i64 4 }] -@str.402 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.403 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.405 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.406 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.407 = private constant [3 x i8] c"fd\00" -@field_names.408 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.407, i64 2 }] -@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.410 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.414 = private constant [5 x i8] c"file\00" -@fld.str.415 = private constant [5 x i8] c"line\00" -@fld.str.416 = private constant [4 x i8] c"col\00" -@fld.str.417 = private constant [5 x i8] c"func\00" -@fld.str.418 = private constant [10 x i8] c"line_text\00" -@field_names.419 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 4 }, { ptr, i64 } { ptr @fld.str.415, i64 4 }, { ptr, i64 } { ptr @fld.str.416, i64 3 }, { ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 9 }] -@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.421 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.422 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.423 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.424 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.425 = private constant [10 x i8] c"exit_code\00" -@fld.str.426 = private constant [7 x i8] c"stdout\00" -@field_names.427 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 9 }, { ptr, i64 } { ptr @fld.str.426, i64 6 }] -@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.429 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.431 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.432 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.433 = private constant [8 x i8] c"sin_len\00" -@fld.str.434 = private constant [11 x i8] c"sin_family\00" -@fld.str.435 = private constant [9 x i8] c"sin_port\00" -@fld.str.436 = private constant [9 x i8] c"sin_addr\00" -@fld.str.437 = private constant [9 x i8] c"sin_zero\00" -@field_names.438 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 7 }, { ptr, i64 } { ptr @fld.str.434, i64 10 }, { ptr, i64 } { ptr @fld.str.435, i64 8 }, { ptr, i64 } { ptr @fld.str.436, i64 8 }, { ptr, i64 } { ptr @fld.str.437, i64 8 }] -@str.439 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.440 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.441 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.442 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.443 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.444 = private constant [6 x i8] c"items\00" -@fld.str.445 = private constant [4 x i8] c"len\00" -@fld.str.446 = private constant [4 x i8] c"cap\00" -@field_names.447 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.444, i64 5 }, { ptr, i64 } { ptr @fld.str.445, i64 3 }, { ptr, i64 } { ptr @fld.str.446, i64 3 }] -@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.449 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.453 = private constant [6 x i8] c"items\00" -@fld.str.454 = private constant [4 x i8] c"len\00" -@fld.str.455 = private constant [4 x i8] c"cap\00" -@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] -@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.458 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.462 = private constant [4 x i8] c"key\00" -@fld.str.463 = private constant [4 x i8] c"val\00" -@field_names.464 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 3 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }] -@str.465 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.466 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.467 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.469 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.470 = private constant [4 x i8] c"dst\00" -@fld.str.471 = private constant [4 x i8] c"pos\00" -@fld.str.472 = private constant [5 x i8] c"file\00" -@field_names.473 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.470, i64 3 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 4 }] -@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.475 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.479 = private constant [4 x i8] c"src\00" -@fld.str.480 = private constant [4 x i8] c"pos\00" -@fld.str.481 = private constant [6 x i8] c"alloc\00" -@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 5 }] -@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.484 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.488 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.490 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.494 = private constant [5 x i8] c"name\00" -@fld.str.495 = private constant [12 x i8] c"takes_value\00" -@fld.str.496 = private constant [9 x i8] c"required\00" -@field_names.497 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.494, i64 4 }, { ptr, i64 } { ptr @fld.str.495, i64 11 }, { ptr, i64 } { ptr @fld.str.496, i64 8 }] -@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.499 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.503 = private constant [6 x i8] c"group\00" -@fld.str.504 = private constant [8 x i8] c"command\00" -@fld.str.505 = private constant [6 x i8] c"flags\00" -@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 5 }, { ptr, i64 } { ptr @fld.str.504, i64 7 }, { ptr, i64 } { ptr @fld.str.505, i64 5 }] -@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.508 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.512 = private constant [4 x i8] c"set\00" -@fld.str.513 = private constant [6 x i8] c"value\00" -@field_names.514 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 3 }, { ptr, i64 } { ptr @fld.str.513, i64 5 }] -@str.515 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.516 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.517 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.519 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.520 = private constant [6 x i8] c"index\00" -@fld.str.521 = private constant [6 x i8] c"token\00" -@field_names.522 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.520, i64 5 }, { ptr, i64 } { ptr @fld.str.521, i64 5 }] -@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.524 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.525 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.526 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.527 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.528 = private constant [6 x i8] c"group\00" -@fld.str.529 = private constant [8 x i8] c"command\00" -@fld.str.530 = private constant [10 x i8] c"cmd_index\00" -@fld.str.531 = private constant [5 x i8] c"json\00" -@fld.str.532 = private constant [5 x i8] c"rest\00" -@fld.str.533 = private constant [5 x i8] c"spec\00" -@fld.str.534 = private constant [7 x i8] c"values\00" -@field_names.535 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.528, i64 5 }, { ptr, i64 } { ptr @fld.str.529, i64 7 }, { ptr, i64 } { ptr @fld.str.530, i64 9 }, { ptr, i64 } { ptr @fld.str.531, i64 4 }, { ptr, i64 } { ptr @fld.str.532, i64 4 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }, { ptr, i64 } { ptr @fld.str.534, i64 6 }] -@str.536 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.537 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.540 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.541 = private constant [2 x i8] c"h\00" -@fld.str.542 = private constant [4 x i8] c"buf\00" -@fld.str.543 = private constant [8 x i8] c"buf_len\00" -@fld.str.544 = private constant [10 x i8] c"total_len\00" -@field_names.545 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.541, i64 1 }, { ptr, i64 } { ptr @fld.str.542, i64 3 }, { ptr, i64 } { ptr @fld.str.543, i64 7 }, { ptr, i64 } { ptr @fld.str.544, i64 9 }] -@str.546 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.548 = private constant [5 x i8] c"read\00" -@fld.str.549 = private constant [6 x i8] c"write\00" -@fld.str.550 = private constant [7 x i8] c"append\00" -@fld.str.551 = private constant [11 x i8] c"read_write\00" -@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 4 }, { ptr, i64 } { ptr @fld.str.549, i64 5 }, { ptr, i64 } { ptr @fld.str.550, i64 6 }, { ptr, i64 } { ptr @fld.str.551, i64 10 }] -@str.553 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.555 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.556 = private constant [4 x i8] c"set\00" -@fld.str.557 = private constant [8 x i8] c"current\00" -@fld.str.558 = private constant [4 x i8] c"end\00" -@field_names.559 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 3 }] -@str.560 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.563 = private constant [6 x i8] c"null_\00" -@fld.str.564 = private constant [6 x i8] c"bool_\00" -@fld.str.565 = private constant [5 x i8] c"int_\00" -@fld.str.566 = private constant [4 x i8] c"str\00" -@fld.str.567 = private constant [6 x i8] c"array\00" -@fld.str.568 = private constant [7 x i8] c"object\00" -@field_names.569 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 4 }, { ptr, i64 } { ptr @fld.str.566, i64 3 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 6 }] -@str.570 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.571 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.572 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.573 = private constant [6 x i8] c"macos\00" -@fld.str.574 = private constant [6 x i8] c"linux\00" -@fld.str.575 = private constant [8 x i8] c"windows\00" -@fld.str.576 = private constant [5 x i8] c"wasm\00" -@fld.str.577 = private constant [4 x i8] c"ios\00" -@fld.str.578 = private constant [8 x i8] c"android\00" -@fld.str.579 = private constant [8 x i8] c"unknown\00" -@field_names.580 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 7 }, { ptr, i64 } { ptr @fld.str.576, i64 4 }, { ptr, i64 } { ptr @fld.str.577, i64 3 }, { ptr, i64 } { ptr @fld.str.578, i64 7 }, { ptr, i64 } { ptr @fld.str.579, i64 7 }] -@str.581 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.582 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.584 = private constant [8 x i8] c"aarch64\00" -@fld.str.585 = private constant [7 x i8] c"x86_64\00" -@fld.str.586 = private constant [7 x i8] c"wasm32\00" -@fld.str.587 = private constant [7 x i8] c"wasm64\00" -@fld.str.588 = private constant [8 x i8] c"unknown\00" -@field_names.589 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 6 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] -@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.592 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.593 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.594 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.595 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.597 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.628 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.629 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.630 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.631 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.632 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.633 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.635 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.638 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.641 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.644 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.647 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.650 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.653 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.656 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.659 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.662 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.668 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.671 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.674 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.677 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.680 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.683 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.689 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.692 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.335 = private constant [5 x i8] c"line\00" +@fld.str.336 = private constant [4 x i8] c"col\00" +@fld.str.337 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.335, i64 4 }, { ptr, i64 } { ptr @fld.str.336, i64 3 }, { ptr, i64 } { ptr @fld.str.337, i64 4 }] +@str.338 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.339 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.340 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.341 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.342 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.343 = private constant [4 x i8] c"ctx\00" +@fld.str.344 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.345 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.346 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 11 }, { ptr, i64 } { ptr @fld.str.345, i64 13 }] +@str.347 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.348 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.349 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.350 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.351 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.352 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.353 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.354 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.357 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.358 = private constant [12 x i8] c"alloc_count\00" +@field_names.359 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.358, i64 11 }] +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [5 x i8] c"next\00" +@fld.str.366 = private constant [4 x i8] c"cap\00" +@field_names.367 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 4 }, { ptr, i64 } { ptr @fld.str.366, i64 3 }] +@str.368 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.369 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.372 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.373 = private constant [6 x i8] c"first\00" +@fld.str.374 = private constant [10 x i8] c"end_index\00" +@fld.str.375 = private constant [7 x i8] c"parent\00" +@field_names.376 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.373, i64 5 }, { ptr, i64 } { ptr @fld.str.374, i64 9 }, { ptr, i64 } { ptr @fld.str.375, i64 6 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.379 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.380 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.381 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.382 = private constant [4 x i8] c"buf\00" +@fld.str.383 = private constant [4 x i8] c"len\00" +@fld.str.384 = private constant [4 x i8] c"pos\00" +@field_names.385 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 3 }, { ptr, i64 } { ptr @fld.str.383, i64 3 }, { ptr, i64 } { ptr @fld.str.384, i64 3 }] +@str.386 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.387 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.388 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.389 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.390 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.391 = private constant [7 x i8] c"parent\00" +@fld.str.392 = private constant [12 x i8] c"alloc_count\00" +@fld.str.393 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.394 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.395 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.391, i64 6 }, { ptr, i64 } { ptr @fld.str.392, i64 11 }, { ptr, i64 } { ptr @fld.str.393, i64 13 }, { ptr, i64 } { ptr @fld.str.394, i64 17 }] +@str.396 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.397 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.398 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.399 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.400 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.401 = private constant [10 x i8] c"allocator\00" +@fld.str.402 = private constant [5 x i8] c"data\00" +@field_names.403 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.401, i64 9 }, { ptr, i64 } { ptr @fld.str.402, i64 4 }] +@str.404 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.405 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.407 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.408 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.409 = private constant [3 x i8] c"fd\00" +@field_names.410 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.409, i64 2 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [5 x i8] c"file\00" +@fld.str.417 = private constant [5 x i8] c"line\00" +@fld.str.418 = private constant [4 x i8] c"col\00" +@fld.str.419 = private constant [5 x i8] c"func\00" +@fld.str.420 = private constant [10 x i8] c"line_text\00" +@field_names.421 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 4 }, { ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 3 }, { ptr, i64 } { ptr @fld.str.419, i64 4 }, { ptr, i64 } { ptr @fld.str.420, i64 9 }] +@str.422 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.423 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.424 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.425 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.426 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.427 = private constant [10 x i8] c"exit_code\00" +@fld.str.428 = private constant [7 x i8] c"stdout\00" +@field_names.429 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.427, i64 9 }, { ptr, i64 } { ptr @fld.str.428, i64 6 }] +@str.430 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.431 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.433 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.434 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.435 = private constant [8 x i8] c"sin_len\00" +@fld.str.436 = private constant [11 x i8] c"sin_family\00" +@fld.str.437 = private constant [9 x i8] c"sin_port\00" +@fld.str.438 = private constant [9 x i8] c"sin_addr\00" +@fld.str.439 = private constant [9 x i8] c"sin_zero\00" +@field_names.440 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.435, i64 7 }, { ptr, i64 } { ptr @fld.str.436, i64 10 }, { ptr, i64 } { ptr @fld.str.437, i64 8 }, { ptr, i64 } { ptr @fld.str.438, i64 8 }, { ptr, i64 } { ptr @fld.str.439, i64 8 }] +@str.441 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.442 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.443 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.444 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.445 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.446 = private constant [6 x i8] c"items\00" +@fld.str.447 = private constant [4 x i8] c"len\00" +@fld.str.448 = private constant [4 x i8] c"cap\00" +@field_names.449 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.446, i64 5 }, { ptr, i64 } { ptr @fld.str.447, i64 3 }, { ptr, i64 } { ptr @fld.str.448, i64 3 }] +@str.450 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.451 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.452 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.454 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.455 = private constant [6 x i8] c"items\00" +@fld.str.456 = private constant [4 x i8] c"len\00" +@fld.str.457 = private constant [4 x i8] c"cap\00" +@field_names.458 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.455, i64 5 }, { ptr, i64 } { ptr @fld.str.456, i64 3 }, { ptr, i64 } { ptr @fld.str.457, i64 3 }] +@str.459 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.460 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.461 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.462 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.463 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.464 = private constant [4 x i8] c"key\00" +@fld.str.465 = private constant [4 x i8] c"val\00" +@field_names.466 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.464, i64 3 }, { ptr, i64 } { ptr @fld.str.465, i64 3 }] +@str.467 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.468 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.469 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.471 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.472 = private constant [4 x i8] c"dst\00" +@fld.str.473 = private constant [4 x i8] c"pos\00" +@fld.str.474 = private constant [5 x i8] c"file\00" +@field_names.475 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 3 }, { ptr, i64 } { ptr @fld.str.474, i64 4 }] +@str.476 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.477 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.478 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.479 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.480 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.481 = private constant [4 x i8] c"src\00" +@fld.str.482 = private constant [4 x i8] c"pos\00" +@fld.str.483 = private constant [6 x i8] c"alloc\00" +@field_names.484 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.481, i64 3 }, { ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 5 }] +@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.486 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.487 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.488 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.489 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.490 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.491 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.492 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.495 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.496 = private constant [5 x i8] c"name\00" +@fld.str.497 = private constant [12 x i8] c"takes_value\00" +@fld.str.498 = private constant [9 x i8] c"required\00" +@field_names.499 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.496, i64 4 }, { ptr, i64 } { ptr @fld.str.497, i64 11 }, { ptr, i64 } { ptr @fld.str.498, i64 8 }] +@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.501 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.504 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.505 = private constant [6 x i8] c"group\00" +@fld.str.506 = private constant [8 x i8] c"command\00" +@fld.str.507 = private constant [6 x i8] c"flags\00" +@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 5 }, { ptr, i64 } { ptr @fld.str.506, i64 7 }, { ptr, i64 } { ptr @fld.str.507, i64 5 }] +@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.510 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.514 = private constant [4 x i8] c"set\00" +@fld.str.515 = private constant [6 x i8] c"value\00" +@field_names.516 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 3 }, { ptr, i64 } { ptr @fld.str.515, i64 5 }] +@str.517 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.518 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.519 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.521 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.522 = private constant [6 x i8] c"index\00" +@fld.str.523 = private constant [6 x i8] c"token\00" +@field_names.524 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.522, i64 5 }, { ptr, i64 } { ptr @fld.str.523, i64 5 }] +@str.525 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.526 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.527 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.528 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.529 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.530 = private constant [6 x i8] c"group\00" +@fld.str.531 = private constant [8 x i8] c"command\00" +@fld.str.532 = private constant [10 x i8] c"cmd_index\00" +@fld.str.533 = private constant [5 x i8] c"json\00" +@fld.str.534 = private constant [5 x i8] c"rest\00" +@fld.str.535 = private constant [5 x i8] c"spec\00" +@fld.str.536 = private constant [7 x i8] c"values\00" +@field_names.537 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 5 }, { ptr, i64 } { ptr @fld.str.531, i64 7 }, { ptr, i64 } { ptr @fld.str.532, i64 9 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }, { ptr, i64 } { ptr @fld.str.534, i64 4 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }, { ptr, i64 } { ptr @fld.str.536, i64 6 }] +@str.538 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.539 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.542 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.543 = private constant [2 x i8] c"h\00" +@fld.str.544 = private constant [4 x i8] c"buf\00" +@fld.str.545 = private constant [8 x i8] c"buf_len\00" +@fld.str.546 = private constant [10 x i8] c"total_len\00" +@field_names.547 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.543, i64 1 }, { ptr, i64 } { ptr @fld.str.544, i64 3 }, { ptr, i64 } { ptr @fld.str.545, i64 7 }, { ptr, i64 } { ptr @fld.str.546, i64 9 }] +@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.550 = private constant [5 x i8] c"read\00" +@fld.str.551 = private constant [6 x i8] c"write\00" +@fld.str.552 = private constant [7 x i8] c"append\00" +@fld.str.553 = private constant [11 x i8] c"read_write\00" +@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 4 }, { ptr, i64 } { ptr @fld.str.551, i64 5 }, { ptr, i64 } { ptr @fld.str.552, i64 6 }, { ptr, i64 } { ptr @fld.str.553, i64 10 }] +@str.555 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.557 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.558 = private constant [4 x i8] c"set\00" +@fld.str.559 = private constant [8 x i8] c"current\00" +@fld.str.560 = private constant [4 x i8] c"end\00" +@field_names.561 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 3 }, { ptr, i64 } { ptr @fld.str.559, i64 7 }, { ptr, i64 } { ptr @fld.str.560, i64 3 }] +@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.565 = private constant [6 x i8] c"null_\00" +@fld.str.566 = private constant [6 x i8] c"bool_\00" +@fld.str.567 = private constant [5 x i8] c"int_\00" +@fld.str.568 = private constant [4 x i8] c"str\00" +@fld.str.569 = private constant [6 x i8] c"array\00" +@fld.str.570 = private constant [7 x i8] c"object\00" +@field_names.571 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 5 }, { ptr, i64 } { ptr @fld.str.567, i64 4 }, { ptr, i64 } { ptr @fld.str.568, i64 3 }, { ptr, i64 } { ptr @fld.str.569, i64 5 }, { ptr, i64 } { ptr @fld.str.570, i64 6 }] +@str.572 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.573 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.574 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.575 = private constant [6 x i8] c"macos\00" +@fld.str.576 = private constant [6 x i8] c"linux\00" +@fld.str.577 = private constant [8 x i8] c"windows\00" +@fld.str.578 = private constant [5 x i8] c"wasm\00" +@fld.str.579 = private constant [4 x i8] c"ios\00" +@fld.str.580 = private constant [8 x i8] c"android\00" +@fld.str.581 = private constant [8 x i8] c"unknown\00" +@field_names.582 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 7 }, { ptr, i64 } { ptr @fld.str.578, i64 4 }, { ptr, i64 } { ptr @fld.str.579, i64 3 }, { ptr, i64 } { ptr @fld.str.580, i64 7 }, { ptr, i64 } { ptr @fld.str.581, i64 7 }] +@str.583 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.584 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.586 = private constant [8 x i8] c"aarch64\00" +@fld.str.587 = private constant [7 x i8] c"x86_64\00" +@fld.str.588 = private constant [7 x i8] c"wasm32\00" +@fld.str.589 = private constant [7 x i8] c"wasm64\00" +@fld.str.590 = private constant [8 x i8] c"unknown\00" +@field_names.591 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.586, i64 7 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }, { ptr, i64 } { ptr @fld.str.588, i64 6 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }] +@str.592 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.594 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.595 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.596 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.597 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.599 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.602 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.603 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.605 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.630 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.631 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.632 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.633 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.634 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.635 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.636 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.637 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.638 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.640 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.643 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.646 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.649 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.652 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.655 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.658 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.661 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.664 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.670 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.673 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.676 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.679 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.682 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.691 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.694 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.721 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -620,6 +620,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -839,7 +842,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -966,7 +969,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1300,7 +1303,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1450,7 +1453,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1476,9 +1479,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1520,9 +1523,9 @@ entry: i64 85, label %match.arm.48 i64 95, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1562,7 +1565,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1606,9 +1609,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1690,9 +1693,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.340 [ i64 18, label %dispatch.case.341 - i64 21, label %dispatch.case.342 - i64 23, label %dispatch.case.343 - i64 25, label %dispatch.case.344 + i64 22, label %dispatch.case.342 + i64 24, label %dispatch.case.343 + i64 26, label %dispatch.case.344 i64 28, label %dispatch.case.345 i64 29, label %dispatch.case.346 i64 31, label %dispatch.case.347 @@ -1790,7 +1793,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1804,32 +1807,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -1999,7 +2002,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2040,7 +2043,7 @@ dispatch.merge.263: ; preds = %dispatch.case.271, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2105,7 +2108,7 @@ dispatch.merge.307: ; preds = %dispatch.case.313, br label %match.merge.37 dispatch.default.308: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2154,7 +2157,7 @@ dispatch.merge.339: ; preds = %dispatch.case.371, br label %match.merge.37 dispatch.default.340: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2380,7 +2383,7 @@ dispatch.merge.478: ; preds = %dispatch.case.483, br label %match.merge.37 dispatch.default.479: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2422,7 +2425,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.311, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2518,7 +2521,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2526,7 +2529,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2536,13 +2539,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2550,7 +2553,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2564,7 +2567,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2572,7 +2575,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2583,7 +2586,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2640,7 +2643,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2648,7 +2651,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2659,7 +2662,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2679,7 +2682,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2687,7 +2690,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, 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 @@ -2698,7 +2701,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2708,64 +2711,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2941,163 +2947,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3295,64 +3304,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3382,97 +3391,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3511,7 +3520,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3577,7 +3586,7 @@ entry: define internal void @print__ct_sbc6305862a3a863d__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.326, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.328, i64 3 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3592,7 +3601,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -3614,7 +3623,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.328, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.330, i64 3 }) ret { ptr, i64 } %call } @@ -3641,7 +3650,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.329, i64 15 }, { ptr, i64 } { ptr @str.330, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.331, i64 15 }, { ptr, i64 } { ptr @str.332, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3660,12 +3669,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3677,7 +3686,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3730,20 +3739,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.337, i64 10 }, { ptr, i64 } { ptr @str.338, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.339, i64 9 }, { ptr, i64 } { ptr @str.340, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3753,224 +3762,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.341, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.346, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 3 }, { ptr, i64 } { ptr @str.344, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.348, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 10 }, { ptr, i64 } { ptr @str.351, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.356, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.358, i64 9 }, { ptr, i64 } { ptr @str.359, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.365, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, 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 @@ -3989,27 +3798,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.348, i64 10 }, { ptr, i64 } { ptr @str.349, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.352, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.354, i64 3 }, { ptr, i64 } { ptr @str.355, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.359, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 10 }, { ptr, i64 } { ptr @str.362, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.367, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4019,7 +4028,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.367, i64 5 }, { ptr, i64 } { ptr @str.368, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.369, i64 5 }, { ptr, i64 } { ptr @str.370, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4038,24 +4047,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.374, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.376, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, 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 @@ -4082,7 +4091,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4094,7 +4103,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4103,7 +4112,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 8 }, { ptr, i64 } { ptr @str.377, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 8 }, { ptr, i64 } { ptr @str.379, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4122,24 +4131,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.383, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.385, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, 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 @@ -4186,7 +4195,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 17 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.387, i64 17 }, { ptr, i64 } { ptr @str.388, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4205,24 +4214,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.393, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.395, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4251,7 +4260,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4276,7 +4285,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.395, i64 7 }, { ptr, i64 } { ptr @str.396, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.397, i64 7 }, { ptr, i64 } { ptr @str.398, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4295,24 +4304,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.401, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.403, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, 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 @@ -4339,7 +4348,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4354,7 +4363,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.403, i64 4 }, { ptr, i64 } { ptr @str.404, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.405, i64 4 }, { ptr, i64 } { ptr @str.406, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4373,24 +4382,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.410, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4427,7 +4436,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 10 }, { ptr, i64 } { ptr @str.411, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 10 }, { ptr, i64 } { ptr @str.413, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4446,24 +4455,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.419, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.421, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4529,7 +4538,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 13 }, { ptr, i64 } { ptr @str.422, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.423, i64 13 }, { ptr, i64 } { ptr @str.424, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4548,24 +4557,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.427, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.429, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4607,7 +4616,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 8 }, { ptr, i64 } { ptr @str.430, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.431, i64 8 }, { ptr, i64 } { ptr @str.432, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4626,24 +4635,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.438, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.440, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4704,7 +4713,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.440, i64 5 }, { ptr, i64 } { ptr @str.441, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.442, i64 5 }, { ptr, i64 } { ptr @str.443, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4723,24 +4732,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.447, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.449, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, 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 @@ -4786,7 +4795,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 6 }, { ptr, i64 } { ptr @str.450, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.451, i64 6 }, { ptr, i64 } { ptr @str.452, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4805,24 +4814,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.456, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.458, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, 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 @@ -4870,7 +4879,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4889,24 +4898,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.464, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.466, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4950,7 +4959,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.466, i64 4 }, { ptr, i64 } { ptr @str.467, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.468, i64 4 }, { ptr, i64 } { ptr @str.469, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4969,24 +4978,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.473, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.475, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5036,7 +5045,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 6 }, { ptr, i64 } { ptr @str.476, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.477, i64 6 }, { ptr, i64 } { ptr @str.478, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5055,24 +5064,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.482, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.484, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5112,7 +5121,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5121,7 +5130,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 12 }, { ptr, i64 } { ptr @str.485, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 12 }, { ptr, i64 } { ptr @str.487, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5140,24 +5149,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.488, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.490, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5177,7 +5186,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 8 }, { ptr, i64 } { ptr @str.491, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5196,24 +5205,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.497, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.499, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5265,7 +5274,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 7 }, { ptr, i64 } { ptr @str.500, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 7 }, { ptr, i64 } { ptr @str.502, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5284,24 +5293,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.506, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.508, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5353,7 +5362,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 9 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 9 }, { ptr, i64 } { ptr @str.511, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5372,24 +5381,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.514, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.516, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5432,7 +5441,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.516, i64 4 }, { ptr, i64 } { ptr @str.517, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.518, i64 4 }, { ptr, i64 } { ptr @str.519, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5451,24 +5460,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.522, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.524, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5514,7 +5523,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 6 }, { ptr, i64 } { ptr @str.525, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 6 }, { ptr, i64 } { ptr @str.527, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5533,24 +5542,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.535, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.537, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5632,7 +5641,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.537, i64 6 }, { ptr, i64 } { ptr @str.538, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.539, i64 6 }, { ptr, i64 } { ptr @str.540, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5651,24 +5660,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.545, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.547, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5727,9 +5736,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.547, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, 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 @@ -5748,8 +5757,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5768,9 +5777,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.557, 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 @@ -5789,8 +5798,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5820,9 +5829,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.569, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.571, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5839,8 +5848,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.570, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -5918,9 +5927,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.582, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, 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 @@ -5939,8 +5948,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -5959,9 +5968,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.591, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, 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 @@ -5980,8 +5989,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -5998,7 +6007,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.592, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.594, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.272 @@ -6015,12 +6024,12 @@ while.body.273: ; preds = %while.hdr.272 while.exit.274: ; preds = %while.hdr.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 1 }) ret { ptr, i64 } %call if.then.275: ; preds = %while.body.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 @@ -6049,7 +6058,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.595, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.597, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.277 @@ -6066,12 +6075,12 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) ret { ptr, i64 } %call if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 @@ -6101,7 +6110,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.598, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.600, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.282 @@ -6118,12 +6127,12 @@ while.body.283: ; preds = %while.hdr.282 while.exit.284: ; preds = %while.hdr.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 1 }) ret { ptr, i64 } %call if.then.285: ; preds = %while.body.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6151,7 +6160,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.603, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.287 @@ -6168,12 +6177,12 @@ while.body.288: ; preds = %while.hdr.287 while.exit.289: ; preds = %while.hdr.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 1 }) ret { ptr, i64 } %call if.then.290: ; preds = %while.body.288 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -6202,7 +6211,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.292 @@ -6219,12 +6228,12 @@ while.body.293: ; preds = %while.hdr.292 while.exit.294: ; preds = %while.hdr.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %call if.then.295: ; preds = %while.body.293 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6253,7 +6262,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.297 @@ -6270,12 +6279,12 @@ while.body.298: ; preds = %while.hdr.297 while.exit.299: ; preds = %while.hdr.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %call if.then.300: ; preds = %while.body.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.301 @@ -6306,7 +6315,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.302 @@ -6323,12 +6332,12 @@ while.body.303: ; preds = %while.hdr.302 while.exit.304: ; preds = %while.hdr.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %call if.then.305: ; preds = %while.body.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.306 @@ -6358,7 +6367,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6377,12 +6386,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6411,7 +6420,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.319 @@ -6430,12 +6439,12 @@ while.body.320: ; preds = %while.hdr.319 while.exit.321: ; preds = %while.hdr.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) ret { ptr, i64 } %call if.then.322: ; preds = %while.body.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.323 @@ -6464,7 +6473,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.324 @@ -6483,12 +6492,12 @@ while.body.325: ; preds = %while.hdr.324 while.exit.326: ; preds = %while.hdr.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) ret { ptr, i64 } %call if.then.327: ; preds = %while.body.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.328 @@ -6518,7 +6527,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.329 @@ -6537,12 +6546,12 @@ while.body.330: ; preds = %while.hdr.329 while.exit.331: ; preds = %while.hdr.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %call if.then.332: ; preds = %while.body.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.333 @@ -6572,7 +6581,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.334 @@ -6591,12 +6600,12 @@ while.body.335: ; preds = %while.hdr.334 while.exit.336: ; preds = %while.hdr.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) ret { ptr, i64 } %call if.then.337: ; preds = %while.body.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.338 @@ -6638,12 +6647,12 @@ if.then.372: ; preds = %entry if.else.373: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 5 }, { ptr, i64 } %callN) br label %if.merge.374 if.merge.374: ; preds = %if.else.373, %if.then.372 - %bp = phi { ptr, i64 } [ { ptr @str.628, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.630, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6666,12 +6675,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.631, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.633, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6694,12 +6703,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 4 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6722,12 +6731,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 11 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6750,12 +6759,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 6 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6777,12 +6786,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 5 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6805,12 +6814,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 9 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6833,12 +6842,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 18 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6861,12 +6870,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 5 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6889,12 +6898,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6917,12 +6926,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6945,12 +6954,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 9 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6973,12 +6982,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 4 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7000,12 +7009,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 8 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7028,12 +7037,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 6 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7055,12 +7064,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 9 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7083,12 +7092,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7111,12 +7120,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 5 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7139,12 +7148,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7167,12 +7176,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 4 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7195,12 +7204,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7223,12 +7232,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 5 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7251,12 +7260,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7279,12 +7288,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 12 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7307,12 +7316,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 6 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7335,12 +7344,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 4 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7363,12 +7372,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7391,12 +7400,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 6 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7419,12 +7428,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7447,12 +7456,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7475,12 +7484,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 5 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7496,7 +7505,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.721, i64 4 } + ret { ptr, i64 } { ptr @str.723, i64 4 } if.merge.485: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7520,7 +7529,7 @@ entry: br i1 %lnot, label %if.then.486, label %if.merge.487 if.then.486: ; preds = %entry - ret { ptr, i64 } { ptr @str.722, i64 4 } + ret { ptr, i64 } { ptr @str.724, i64 4 } if.merge.487: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7544,7 +7553,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.723, i64 4 } + ret { ptr, i64 } { ptr @str.725, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7568,7 +7577,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.724, i64 4 } + ret { ptr, i64 } { ptr @str.726, i64 4 } if.merge.491: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0518-packs-pack-value-dispatch.ir b/examples/expected/0518-packs-pack-value-dispatch.ir index ff68519..b4b29e3 100644 --- a/examples/expected/0518-packs-pack-value-dispatch.ir +++ b/examples/expected/0518-packs-pack-value-dispatch.ir @@ -1,617 +1,617 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [160 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.237 = private constant [7 x i8] c"**void\00" -@tn.str.238 = private constant [6 x i8] c"[]Any\00" -@tn.str.239 = private constant [5 x i8] c"*Any\00" -@tn.str.240 = private constant [7 x i8] c"[1]Any\00" -@tn.str.241 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.242 = private constant [7 x i8] c"*[]Any\00" -@tn.str.243 = private constant [8 x i8] c"*string\00" -@tn.str.244 = private constant [6 x i8] c"*bool\00" -@tn.str.245 = private constant [5 x i8] c"*f64\00" -@tn.str.246 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.247 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.248 = private constant [11 x i8] c"*Allocator\00" -@tn.str.249 = private constant [9 x i8] c"*Context\00" -@tn.str.250 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.251 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.252 = private constant [8 x i8] c"*Member\00" -@tn.str.253 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.254 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.255 = private constant [9 x i8] c"*Command\00" -@tn.str.256 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.257 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.258 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.259 = private constant [7 x i8] c"*Value\00" -@tn.str.260 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.261 = private constant [14 x i8] c"*Architecture\00" -@tn.str.262 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.263 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.264 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.265 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.266 = private constant [10 x i8] c"*[]string\00" -@tn.str.267 = private constant [6 x i8] c"*[]u8\00" -@tn.str.268 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.269 = private constant [11 x i8] c"*[]Command\00" -@tn.str.270 = private constant [6 x i8] c"**GPA\00" -@tn.str.271 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.272 = private constant [8 x i8] c"**Arena\00" -@tn.str.273 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.274 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.275 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.276 = private constant [7 x i8] c"**File\00" -@tn.str.277 = private constant [5 x i8] c"**u8\00" -@tn.str.278 = private constant [6 x i8] c"**s32\00" -@tn.str.279 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.280 = private constant [6 x i8] c"**u32\00" -@tn.str.281 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.282 = private constant [8 x i8] c"**Array\00" -@tn.str.283 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.284 = private constant [9 x i8] c"**Object\00" -@tn.str.285 = private constant [7 x i8] c"**Sink\00" -@tn.str.286 = private constant [9 x i8] c"**Parser\00" -@tn.str.287 = private constant [6 x i8] c"**s64\00" -@tn.str.288 = private constant [9 x i8] c"**Parsed\00" -@tn.str.289 = private constant [7 x i8] c"**Diag\00" -@tn.str.290 = private constant [9 x i8] c"**Sha256\00" -@tn.str.291 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.292 = private constant [8 x i8] c"***void\00" -@tn.str.293 = private constant [6 x i8] c"**Any\00" -@tn.str.294 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.295 = private constant [8 x i8] c"**[]Any\00" -@tn.str.296 = private constant [9 x i8] c"**string\00" -@tn.str.297 = private constant [7 x i8] c"**bool\00" -@tn.str.298 = private constant [6 x i8] c"**f64\00" -@tn.str.299 = private constant [7 x i8] c"*?File\00" -@tn.str.300 = private constant [9 x i8] c"*?string\00" -@tn.str.301 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.302 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [160 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 12 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 5 }, { ptr, i64 } { ptr @tn.str.239, i64 4 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 5 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 16 }, { ptr, i64 } { ptr @tn.str.248, i64 10 }, { ptr, i64 } { ptr @tn.str.249, i64 8 }, { ptr, i64 } { ptr @tn.str.250, i64 11 }, { ptr, i64 } { ptr @tn.str.251, i64 14 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 13 }, { ptr, i64 } { ptr @tn.str.254, i64 9 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 9 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 6 }, { ptr, i64 } { ptr @tn.str.260, i64 16 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 14 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 7 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 9 }, { ptr, i64 } { ptr @tn.str.267, i64 5 }, { ptr, i64 } { ptr @tn.str.268, i64 11 }, { ptr, i64 } { ptr @tn.str.269, i64 10 }, { ptr, i64 } { ptr @tn.str.270, i64 5 }, { ptr, i64 } { ptr @tn.str.271, i64 12 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 6 }, { ptr, i64 } { ptr @tn.str.274, i64 10 }, { ptr, i64 } { ptr @tn.str.275, i64 19 }, { ptr, i64 } { ptr @tn.str.276, i64 6 }, { ptr, i64 } { ptr @tn.str.277, i64 4 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 10 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 9 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 8 }, { ptr, i64 } { ptr @tn.str.285, i64 6 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 5 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 13 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 7 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 15 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }] -@str.303 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.304 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.239 = private constant [7 x i8] c"**void\00" +@tn.str.240 = private constant [6 x i8] c"[]Any\00" +@tn.str.241 = private constant [5 x i8] c"*Any\00" +@tn.str.242 = private constant [7 x i8] c"[1]Any\00" +@tn.str.243 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.244 = private constant [7 x i8] c"*[]Any\00" +@tn.str.245 = private constant [8 x i8] c"*string\00" +@tn.str.246 = private constant [6 x i8] c"*bool\00" +@tn.str.247 = private constant [5 x i8] c"*f64\00" +@tn.str.248 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.249 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.250 = private constant [11 x i8] c"*Allocator\00" +@tn.str.251 = private constant [9 x i8] c"*Context\00" +@tn.str.252 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.253 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.254 = private constant [8 x i8] c"*Member\00" +@tn.str.255 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.256 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.257 = private constant [9 x i8] c"*Command\00" +@tn.str.258 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.259 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.260 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.261 = private constant [7 x i8] c"*Value\00" +@tn.str.262 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.263 = private constant [14 x i8] c"*Architecture\00" +@tn.str.264 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.265 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.266 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.267 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.268 = private constant [10 x i8] c"*[]string\00" +@tn.str.269 = private constant [6 x i8] c"*[]u8\00" +@tn.str.270 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.271 = private constant [11 x i8] c"*[]Command\00" +@tn.str.272 = private constant [6 x i8] c"**GPA\00" +@tn.str.273 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.274 = private constant [8 x i8] c"**Arena\00" +@tn.str.275 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.276 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.277 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.278 = private constant [7 x i8] c"**File\00" +@tn.str.279 = private constant [5 x i8] c"**u8\00" +@tn.str.280 = private constant [6 x i8] c"**s32\00" +@tn.str.281 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.282 = private constant [6 x i8] c"**u32\00" +@tn.str.283 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.284 = private constant [8 x i8] c"**Array\00" +@tn.str.285 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.286 = private constant [9 x i8] c"**Object\00" +@tn.str.287 = private constant [7 x i8] c"**Sink\00" +@tn.str.288 = private constant [9 x i8] c"**Parser\00" +@tn.str.289 = private constant [6 x i8] c"**s64\00" +@tn.str.290 = private constant [9 x i8] c"**Parsed\00" +@tn.str.291 = private constant [7 x i8] c"**Diag\00" +@tn.str.292 = private constant [9 x i8] c"**Sha256\00" +@tn.str.293 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.294 = private constant [8 x i8] c"***void\00" +@tn.str.295 = private constant [6 x i8] c"**Any\00" +@tn.str.296 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.297 = private constant [8 x i8] c"**[]Any\00" +@tn.str.298 = private constant [9 x i8] c"**string\00" +@tn.str.299 = private constant [7 x i8] c"**bool\00" +@tn.str.300 = private constant [6 x i8] c"**f64\00" +@tn.str.301 = private constant [7 x i8] c"*?File\00" +@tn.str.302 = private constant [9 x i8] c"*?string\00" +@tn.str.303 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.304 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [160 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 12 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 5 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 4 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 16 }, { ptr, i64 } { ptr @tn.str.250, i64 10 }, { ptr, i64 } { ptr @tn.str.251, i64 8 }, { ptr, i64 } { ptr @tn.str.252, i64 11 }, { ptr, i64 } { ptr @tn.str.253, i64 14 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 13 }, { ptr, i64 } { ptr @tn.str.256, i64 9 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 6 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 8 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 5 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 12 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 6 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 19 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 4 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 10 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 8 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 13 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 7 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 15 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }] @str.305 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.306 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.309 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.310 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.311 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.312 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.313 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.314 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.315 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.316 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.317 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.324 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 -@str.325 = private unnamed_addr constant [6 x i8] c"hello\00", align 1 -@str.326 = private unnamed_addr constant [4 x i8] c"s64\00", align 1 -@str.327 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.328 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.311 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.312 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.313 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.314 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.315 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.316 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.317 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.318 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.319 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.320 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.321 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.322 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.326 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 +@str.327 = private unnamed_addr constant [6 x i8] c"hello\00", align 1 +@str.328 = private unnamed_addr constant [4 x i8] c"s64\00", align 1 @str.329 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.330 = private unnamed_addr constant [7 x i8] c"string\00", align 1 -@str.331 = private unnamed_addr constant [4 x i8] c"f64\00", align 1 -@str.332 = private unnamed_addr constant [8 x i8] c"got s64\00", align 1 -@str.333 = private unnamed_addr constant [11 x i8] c"got string\00", align 1 -@str.334 = private unnamed_addr constant [9 x i8] c"got bool\00", align 1 -@str.335 = private unnamed_addr constant [10 x i8] c"got other\00", align 1 -@str.336 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.337 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.338 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.330 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.331 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.332 = private unnamed_addr constant [7 x i8] c"string\00", align 1 +@str.333 = private unnamed_addr constant [4 x i8] c"f64\00", align 1 +@str.334 = private unnamed_addr constant [8 x i8] c"got s64\00", align 1 +@str.335 = private unnamed_addr constant [11 x i8] c"got string\00", align 1 +@str.336 = private unnamed_addr constant [9 x i8] c"got bool\00", align 1 +@str.337 = private unnamed_addr constant [10 x i8] c"got other\00", align 1 +@str.338 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.339 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.340 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.340 = private constant [5 x i8] c"line\00" -@fld.str.341 = private constant [4 x i8] c"col\00" -@fld.str.342 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.340, i64 4 }, { ptr, i64 } { ptr @fld.str.341, i64 3 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }] -@str.343 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.344 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.346 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.348 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.350 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.354 = private constant [12 x i8] c"alloc_count\00" -@field_names.355 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 11 }] -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.361 = private constant [5 x i8] c"next\00" -@fld.str.362 = private constant [4 x i8] c"cap\00" -@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 4 }, { ptr, i64 } { ptr @fld.str.362, i64 3 }] -@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.365 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.367 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.369 = private constant [4 x i8] c"ctx\00" -@fld.str.370 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.371 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.372 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.369, i64 3 }, { ptr, i64 } { ptr @fld.str.370, i64 11 }, { ptr, i64 } { ptr @fld.str.371, i64 13 }] -@str.373 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.374 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.375 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.376 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.377 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.378 = private constant [6 x i8] c"first\00" -@fld.str.379 = private constant [10 x i8] c"end_index\00" -@fld.str.380 = private constant [7 x i8] c"parent\00" -@field_names.381 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.378, i64 5 }, { ptr, i64 } { ptr @fld.str.379, i64 9 }, { ptr, i64 } { ptr @fld.str.380, i64 6 }] -@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.383 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.387 = private constant [4 x i8] c"buf\00" -@fld.str.388 = private constant [4 x i8] c"len\00" -@fld.str.389 = private constant [4 x i8] c"pos\00" -@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }] -@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.392 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.396 = private constant [7 x i8] c"parent\00" -@fld.str.397 = private constant [12 x i8] c"alloc_count\00" -@fld.str.398 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.399 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.400 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 6 }, { ptr, i64 } { ptr @fld.str.397, i64 11 }, { ptr, i64 } { ptr @fld.str.398, i64 13 }, { ptr, i64 } { ptr @fld.str.399, i64 17 }] -@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.402 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.405 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.406 = private constant [10 x i8] c"allocator\00" -@fld.str.407 = private constant [5 x i8] c"data\00" -@field_names.408 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 9 }, { ptr, i64 } { ptr @fld.str.407, i64 4 }] -@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.410 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.414 = private constant [3 x i8] c"fd\00" -@field_names.415 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 2 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [5 x i8] c"file\00" -@fld.str.422 = private constant [5 x i8] c"line\00" -@fld.str.423 = private constant [4 x i8] c"col\00" -@fld.str.424 = private constant [5 x i8] c"func\00" -@fld.str.425 = private constant [10 x i8] c"line_text\00" -@field_names.426 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 9 }] -@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.428 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.432 = private constant [10 x i8] c"exit_code\00" -@fld.str.433 = private constant [7 x i8] c"stdout\00" -@field_names.434 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 9 }, { ptr, i64 } { ptr @fld.str.433, i64 6 }] -@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.436 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.439 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.440 = private constant [8 x i8] c"sin_len\00" -@fld.str.441 = private constant [11 x i8] c"sin_family\00" -@fld.str.442 = private constant [9 x i8] c"sin_port\00" -@fld.str.443 = private constant [9 x i8] c"sin_addr\00" -@fld.str.444 = private constant [9 x i8] c"sin_zero\00" -@field_names.445 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 7 }, { ptr, i64 } { ptr @fld.str.441, i64 10 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }] -@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.447 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.449 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.450 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.451 = private constant [6 x i8] c"items\00" -@fld.str.452 = private constant [4 x i8] c"len\00" -@fld.str.453 = private constant [4 x i8] c"cap\00" -@field_names.454 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 5 }, { ptr, i64 } { ptr @fld.str.452, i64 3 }, { ptr, i64 } { ptr @fld.str.453, i64 3 }] -@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.456 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.460 = private constant [6 x i8] c"items\00" -@fld.str.461 = private constant [4 x i8] c"len\00" -@fld.str.462 = private constant [4 x i8] c"cap\00" -@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] -@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.465 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.469 = private constant [4 x i8] c"key\00" -@fld.str.470 = private constant [4 x i8] c"val\00" -@field_names.471 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }] -@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.473 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.477 = private constant [4 x i8] c"dst\00" -@fld.str.478 = private constant [4 x i8] c"pos\00" -@fld.str.479 = private constant [5 x i8] c"file\00" -@field_names.480 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 4 }] -@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.482 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.486 = private constant [4 x i8] c"src\00" -@fld.str.487 = private constant [4 x i8] c"pos\00" -@fld.str.488 = private constant [6 x i8] c"alloc\00" -@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 5 }] -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.495 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.497 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.501 = private constant [5 x i8] c"name\00" -@fld.str.502 = private constant [12 x i8] c"takes_value\00" -@fld.str.503 = private constant [9 x i8] c"required\00" -@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 4 }, { ptr, i64 } { ptr @fld.str.502, i64 11 }, { ptr, i64 } { ptr @fld.str.503, i64 8 }] -@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.506 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.510 = private constant [6 x i8] c"group\00" -@fld.str.511 = private constant [8 x i8] c"command\00" -@fld.str.512 = private constant [6 x i8] c"flags\00" -@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 5 }, { ptr, i64 } { ptr @fld.str.511, i64 7 }, { ptr, i64 } { ptr @fld.str.512, i64 5 }] -@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.515 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.519 = private constant [4 x i8] c"set\00" -@fld.str.520 = private constant [6 x i8] c"value\00" -@field_names.521 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 3 }, { ptr, i64 } { ptr @fld.str.520, i64 5 }] -@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.523 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.525 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.526 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.527 = private constant [6 x i8] c"index\00" -@fld.str.528 = private constant [6 x i8] c"token\00" -@field_names.529 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 5 }, { ptr, i64 } { ptr @fld.str.528, i64 5 }] -@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.531 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.533 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.534 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.535 = private constant [6 x i8] c"group\00" -@fld.str.536 = private constant [8 x i8] c"command\00" -@fld.str.537 = private constant [10 x i8] c"cmd_index\00" -@fld.str.538 = private constant [5 x i8] c"json\00" -@fld.str.539 = private constant [5 x i8] c"rest\00" -@fld.str.540 = private constant [5 x i8] c"spec\00" -@fld.str.541 = private constant [7 x i8] c"values\00" -@field_names.542 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 5 }, { ptr, i64 } { ptr @fld.str.536, i64 7 }, { ptr, i64 } { ptr @fld.str.537, i64 9 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 6 }] -@str.543 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.544 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.547 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.548 = private constant [2 x i8] c"h\00" -@fld.str.549 = private constant [4 x i8] c"buf\00" -@fld.str.550 = private constant [8 x i8] c"buf_len\00" -@fld.str.551 = private constant [10 x i8] c"total_len\00" -@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 1 }, { ptr, i64 } { ptr @fld.str.549, i64 3 }, { ptr, i64 } { ptr @fld.str.550, i64 7 }, { ptr, i64 } { ptr @fld.str.551, i64 9 }] -@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.555 = private constant [5 x i8] c"read\00" -@fld.str.556 = private constant [6 x i8] c"write\00" -@fld.str.557 = private constant [7 x i8] c"append\00" -@fld.str.558 = private constant [11 x i8] c"read_write\00" -@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 5 }, { ptr, i64 } { ptr @fld.str.557, i64 6 }, { ptr, i64 } { ptr @fld.str.558, i64 10 }] -@str.560 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.563 = private constant [4 x i8] c"set\00" -@fld.str.564 = private constant [8 x i8] c"current\00" -@fld.str.565 = private constant [4 x i8] c"end\00" -@field_names.566 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 3 }, { ptr, i64 } { ptr @fld.str.564, i64 7 }, { ptr, i64 } { ptr @fld.str.565, i64 3 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [6 x i8] c"null_\00" -@fld.str.571 = private constant [6 x i8] c"bool_\00" -@fld.str.572 = private constant [5 x i8] c"int_\00" -@fld.str.573 = private constant [4 x i8] c"str\00" -@fld.str.574 = private constant [6 x i8] c"array\00" -@fld.str.575 = private constant [7 x i8] c"object\00" -@field_names.576 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 4 }, { ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 6 }] -@str.577 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.579 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.580 = private constant [6 x i8] c"macos\00" -@fld.str.581 = private constant [6 x i8] c"linux\00" -@fld.str.582 = private constant [8 x i8] c"windows\00" -@fld.str.583 = private constant [5 x i8] c"wasm\00" -@fld.str.584 = private constant [4 x i8] c"ios\00" -@fld.str.585 = private constant [8 x i8] c"android\00" -@fld.str.586 = private constant [8 x i8] c"unknown\00" -@field_names.587 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 7 }] -@str.588 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.591 = private constant [8 x i8] c"aarch64\00" -@fld.str.592 = private constant [7 x i8] c"x86_64\00" -@fld.str.593 = private constant [7 x i8] c"wasm32\00" -@fld.str.594 = private constant [7 x i8] c"wasm64\00" -@fld.str.595 = private constant [8 x i8] c"unknown\00" -@field_names.596 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 6 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] -@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.604 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.607 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.632 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.633 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.634 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.635 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.636 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.637 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.638 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.639 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.640 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.642 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.645 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.648 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.651 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.654 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.657 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.666 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.669 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.672 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.675 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.678 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.681 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.684 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.687 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.693 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.696 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.342 = private constant [5 x i8] c"line\00" +@fld.str.343 = private constant [4 x i8] c"col\00" +@fld.str.344 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }, { ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 4 }] +@str.345 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.346 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.347 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.348 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.349 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.350 = private constant [4 x i8] c"ctx\00" +@fld.str.351 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.352 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.353 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.350, i64 3 }, { ptr, i64 } { ptr @fld.str.351, i64 11 }, { ptr, i64 } { ptr @fld.str.352, i64 13 }] +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.359 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [12 x i8] c"alloc_count\00" +@field_names.366 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 11 }] +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.372 = private constant [5 x i8] c"next\00" +@fld.str.373 = private constant [4 x i8] c"cap\00" +@field_names.374 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 4 }, { ptr, i64 } { ptr @fld.str.373, i64 3 }] +@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.376 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.380 = private constant [6 x i8] c"first\00" +@fld.str.381 = private constant [10 x i8] c"end_index\00" +@fld.str.382 = private constant [7 x i8] c"parent\00" +@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 5 }, { ptr, i64 } { ptr @fld.str.381, i64 9 }, { ptr, i64 } { ptr @fld.str.382, i64 6 }] +@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.385 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.389 = private constant [4 x i8] c"buf\00" +@fld.str.390 = private constant [4 x i8] c"len\00" +@fld.str.391 = private constant [4 x i8] c"pos\00" +@field_names.392 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 3 }, { ptr, i64 } { ptr @fld.str.391, i64 3 }] +@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.394 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.395 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.396 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.397 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.398 = private constant [7 x i8] c"parent\00" +@fld.str.399 = private constant [12 x i8] c"alloc_count\00" +@fld.str.400 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.401 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.402 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 6 }, { ptr, i64 } { ptr @fld.str.399, i64 11 }, { ptr, i64 } { ptr @fld.str.400, i64 13 }, { ptr, i64 } { ptr @fld.str.401, i64 17 }] +@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.404 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.408 = private constant [10 x i8] c"allocator\00" +@fld.str.409 = private constant [5 x i8] c"data\00" +@field_names.410 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 9 }, { ptr, i64 } { ptr @fld.str.409, i64 4 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [3 x i8] c"fd\00" +@field_names.417 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 2 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [5 x i8] c"file\00" +@fld.str.424 = private constant [5 x i8] c"line\00" +@fld.str.425 = private constant [4 x i8] c"col\00" +@fld.str.426 = private constant [5 x i8] c"func\00" +@fld.str.427 = private constant [10 x i8] c"line_text\00" +@field_names.428 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }, { ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 9 }] +@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.430 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.434 = private constant [10 x i8] c"exit_code\00" +@fld.str.435 = private constant [7 x i8] c"stdout\00" +@field_names.436 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 9 }, { ptr, i64 } { ptr @fld.str.435, i64 6 }] +@str.437 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.438 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.441 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.442 = private constant [8 x i8] c"sin_len\00" +@fld.str.443 = private constant [11 x i8] c"sin_family\00" +@fld.str.444 = private constant [9 x i8] c"sin_port\00" +@fld.str.445 = private constant [9 x i8] c"sin_addr\00" +@fld.str.446 = private constant [9 x i8] c"sin_zero\00" +@field_names.447 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 7 }, { ptr, i64 } { ptr @fld.str.443, i64 10 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }] +@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.449 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.453 = private constant [6 x i8] c"items\00" +@fld.str.454 = private constant [4 x i8] c"len\00" +@fld.str.455 = private constant [4 x i8] c"cap\00" +@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.462 = private constant [6 x i8] c"items\00" +@fld.str.463 = private constant [4 x i8] c"len\00" +@fld.str.464 = private constant [4 x i8] c"cap\00" +@field_names.465 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 5 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }, { ptr, i64 } { ptr @fld.str.464, i64 3 }] +@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.467 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.468 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.469 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.470 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.471 = private constant [4 x i8] c"key\00" +@fld.str.472 = private constant [4 x i8] c"val\00" +@field_names.473 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }] +@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.475 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.479 = private constant [4 x i8] c"dst\00" +@fld.str.480 = private constant [4 x i8] c"pos\00" +@fld.str.481 = private constant [5 x i8] c"file\00" +@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 4 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.488 = private constant [4 x i8] c"src\00" +@fld.str.489 = private constant [4 x i8] c"pos\00" +@fld.str.490 = private constant [6 x i8] c"alloc\00" +@field_names.491 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 5 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.497 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.499 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.503 = private constant [5 x i8] c"name\00" +@fld.str.504 = private constant [12 x i8] c"takes_value\00" +@fld.str.505 = private constant [9 x i8] c"required\00" +@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 4 }, { ptr, i64 } { ptr @fld.str.504, i64 11 }, { ptr, i64 } { ptr @fld.str.505, i64 8 }] +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.512 = private constant [6 x i8] c"group\00" +@fld.str.513 = private constant [8 x i8] c"command\00" +@fld.str.514 = private constant [6 x i8] c"flags\00" +@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 5 }, { ptr, i64 } { ptr @fld.str.513, i64 7 }, { ptr, i64 } { ptr @fld.str.514, i64 5 }] +@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.517 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.521 = private constant [4 x i8] c"set\00" +@fld.str.522 = private constant [6 x i8] c"value\00" +@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 5 }] +@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.525 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.529 = private constant [6 x i8] c"index\00" +@fld.str.530 = private constant [6 x i8] c"token\00" +@field_names.531 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 5 }, { ptr, i64 } { ptr @fld.str.530, i64 5 }] +@str.532 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.533 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.535 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.536 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.537 = private constant [6 x i8] c"group\00" +@fld.str.538 = private constant [8 x i8] c"command\00" +@fld.str.539 = private constant [10 x i8] c"cmd_index\00" +@fld.str.540 = private constant [5 x i8] c"json\00" +@fld.str.541 = private constant [5 x i8] c"rest\00" +@fld.str.542 = private constant [5 x i8] c"spec\00" +@fld.str.543 = private constant [7 x i8] c"values\00" +@field_names.544 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.537, i64 5 }, { ptr, i64 } { ptr @fld.str.538, i64 7 }, { ptr, i64 } { ptr @fld.str.539, i64 9 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 6 }] +@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.546 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.550 = private constant [2 x i8] c"h\00" +@fld.str.551 = private constant [4 x i8] c"buf\00" +@fld.str.552 = private constant [8 x i8] c"buf_len\00" +@fld.str.553 = private constant [10 x i8] c"total_len\00" +@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 1 }, { ptr, i64 } { ptr @fld.str.551, i64 3 }, { ptr, i64 } { ptr @fld.str.552, i64 7 }, { ptr, i64 } { ptr @fld.str.553, i64 9 }] +@str.555 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.557 = private constant [5 x i8] c"read\00" +@fld.str.558 = private constant [6 x i8] c"write\00" +@fld.str.559 = private constant [7 x i8] c"append\00" +@fld.str.560 = private constant [11 x i8] c"read_write\00" +@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 5 }, { ptr, i64 } { ptr @fld.str.559, i64 6 }, { ptr, i64 } { ptr @fld.str.560, i64 10 }] +@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.565 = private constant [4 x i8] c"set\00" +@fld.str.566 = private constant [8 x i8] c"current\00" +@fld.str.567 = private constant [4 x i8] c"end\00" +@field_names.568 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 7 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [6 x i8] c"null_\00" +@fld.str.573 = private constant [6 x i8] c"bool_\00" +@fld.str.574 = private constant [5 x i8] c"int_\00" +@fld.str.575 = private constant [4 x i8] c"str\00" +@fld.str.576 = private constant [6 x i8] c"array\00" +@fld.str.577 = private constant [7 x i8] c"object\00" +@field_names.578 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 4 }, { ptr, i64 } { ptr @fld.str.575, i64 3 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 6 }] +@str.579 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.581 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.582 = private constant [6 x i8] c"macos\00" +@fld.str.583 = private constant [6 x i8] c"linux\00" +@fld.str.584 = private constant [8 x i8] c"windows\00" +@fld.str.585 = private constant [5 x i8] c"wasm\00" +@fld.str.586 = private constant [4 x i8] c"ios\00" +@fld.str.587 = private constant [8 x i8] c"android\00" +@fld.str.588 = private constant [8 x i8] c"unknown\00" +@field_names.589 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.582, i64 5 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 4 }, { ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] +@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.593 = private constant [8 x i8] c"aarch64\00" +@fld.str.594 = private constant [7 x i8] c"x86_64\00" +@fld.str.595 = private constant [7 x i8] c"wasm32\00" +@fld.str.596 = private constant [7 x i8] c"wasm64\00" +@fld.str.597 = private constant [8 x i8] c"unknown\00" +@field_names.598 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 7 }] +@str.599 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.635 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.638 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.641 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.644 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.647 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.650 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.653 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.656 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.659 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.668 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.671 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.674 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.677 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.680 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.683 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.686 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.689 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.695 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.698 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -624,6 +624,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -843,7 +846,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -970,7 +973,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1304,7 +1307,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1454,7 +1457,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1480,9 +1483,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1523,9 +1526,9 @@ entry: i64 85, label %match.arm.48 i64 95, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1565,7 +1568,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1609,9 +1612,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1692,9 +1695,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.334 [ i64 18, label %dispatch.case.335 - i64 21, label %dispatch.case.336 - i64 23, label %dispatch.case.337 - i64 25, label %dispatch.case.338 + i64 22, label %dispatch.case.336 + i64 24, label %dispatch.case.337 + i64 26, label %dispatch.case.338 i64 28, label %dispatch.case.339 i64 29, label %dispatch.case.340 i64 31, label %dispatch.case.341 @@ -1792,7 +1795,7 @@ dispatch.merge.94: ; preds = %dispatch.case.120, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.303, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1806,32 +1809,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2001,7 +2004,7 @@ dispatch.merge.246: ; preds = %dispatch.case.252, br label %match.merge.37 dispatch.default.247: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.304, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2042,7 +2045,7 @@ dispatch.merge.263: ; preds = %dispatch.case.270, br label %match.merge.37 dispatch.default.264: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.305, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2099,7 +2102,7 @@ dispatch.merge.301: ; preds = %dispatch.case.307, br label %match.merge.37 dispatch.default.302: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.301 dispatch.case.303: ; preds = %match.arm.48 @@ -2148,7 +2151,7 @@ dispatch.merge.333: ; preds = %dispatch.case.365, br label %match.merge.37 dispatch.default.334: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.49 @@ -2374,7 +2377,7 @@ dispatch.merge.472: ; preds = %dispatch.case.477, br label %match.merge.37 dispatch.default.473: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.472 dispatch.case.474: ; preds = %match.arm.50 @@ -2416,7 +2419,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.309, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2512,7 +2515,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.310, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2520,7 +2523,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.311, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2530,13 +2533,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.312, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.313, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2544,7 +2547,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2558,7 +2561,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2566,7 +2569,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2577,7 +2580,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2634,7 +2637,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2642,7 +2645,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2653,7 +2656,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2673,7 +2676,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2681,7 +2684,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, 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 @@ -2692,7 +2695,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2702,64 +2705,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2935,163 +2941,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3289,64 +3298,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3376,97 +3385,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3505,20 +3514,20 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { entry: %call = call { ptr, i64 } @show__pack_s64(ptr @__sx_default_context, i64 42) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %call) - %callN = call { ptr, i64 } @show__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.324, i64 2 }) + %callN = call { ptr, i64 } @show__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.326, i64 2 }) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %callN) %callN = call { ptr, i64 } @show__pack_f64(ptr @__sx_default_context, double 3.140000e+00) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %callN) %callN = call { ptr, i64 } @describe__pack_s64(ptr @__sx_default_context, i64 42) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %callN) - %callN = call { ptr, i64 } @describe__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.325, i64 5 }) + %callN = call { ptr, i64 } @describe__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.327, i64 5 }) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %callN) %callN = call { ptr, i64 } @describe__pack_bool(ptr @__sx_default_context, i1 true) call void @print__ct_sbc6305862a3a863d__pack_string(ptr @__sx_default_context, { ptr, i64 } %callN) @@ -3557,14 +3566,14 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.326, i64 3 } + ret { ptr, i64 } { ptr @str.328, i64 3 } } ; Function Attrs: nounwind define internal void @print__ct_sbc6305862a3a863d__pack_string(ptr %0, { ptr, i64 } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.327, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.329, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3582,7 +3591,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %ba.tmp9 = alloca { ptr, i64 }, align 8 @@ -3607,7 +3616,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.329, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.331, i64 3 }) ret { ptr, i64 } %call } @@ -3630,7 +3639,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.330, i64 6 } + ret { ptr, i64 } { ptr @str.332, i64 6 } } ; Function Attrs: nounwind @@ -3650,7 +3659,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.331, i64 3 } + ret { ptr, i64 } { ptr @str.333, i64 3 } } ; Function Attrs: nounwind @@ -3669,7 +3678,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.332, i64 7 } + ret { ptr, i64 } { ptr @str.334, i64 7 } } ; Function Attrs: nounwind @@ -3691,7 +3700,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.333, i64 10 } + ret { ptr, i64 } { ptr @str.335, i64 10 } } ; Function Attrs: nounwind @@ -3711,7 +3720,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.334, i64 8 } + ret { ptr, i64 } { ptr @str.336, i64 8 } } ; Function Attrs: nounwind @@ -3731,7 +3740,7 @@ entry: store ptr %igp.ptr3, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 - ret { ptr, i64 } { ptr @str.335, i64 9 } + ret { ptr, i64 } { ptr @str.337, i64 9 } } ; Function Attrs: nounwind @@ -3741,7 +3750,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.336, i64 15 }, { ptr, i64 } { ptr @str.337, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.338, i64 15 }, { ptr, i64 } { ptr @str.339, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3760,12 +3769,12 @@ while.body.122: ; preds = %while.hdr.121 while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 1 }) ret { ptr, i64 } %callN if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3777,7 +3786,7 @@ if.merge.125: ; preds = %if.then.124, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3830,20 +3839,20 @@ fv.case24: ; preds = %if.merge.125 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.344, i64 10 }, { ptr, i64 } { ptr @str.345, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.346, i64 9 }, { ptr, i64 } { ptr @str.347, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.126 -while.hdr.126: ; preds = %if.merge.130, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.127, label %while.exit.128 while.body.127: ; preds = %while.hdr.126 @@ -3853,224 +3862,24 @@ while.body.127: ; preds = %while.hdr.126 while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 1 }) ret { ptr, i64 } %callN if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 if.merge.130: ; preds = %if.then.129, %while.body.127 %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.348, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.353, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.126 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 3 }, { ptr, i64 } { ptr @str.351, 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.131 - -while.hdr.131: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.132, label %while.exit.133 - -while.body.132: ; preds = %while.hdr.131 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.134, label %if.merge.135 - -while.exit.133: ; preds = %while.hdr.131 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) - ret { ptr, i64 } %callN - -if.then.134: ; preds = %while.body.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 - -if.merge.135: ; preds = %if.then.134, %while.body.132 - %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.355, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 - -fv.default: ; preds = %if.merge.135 - br label %fv.merge - -fv.case: ; preds = %if.merge.135 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 10 }, { ptr, i64 } { ptr @str.358, 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.136 - -while.hdr.136: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.137, label %while.exit.138 - -while.body.137: ; preds = %while.hdr.136 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.139, label %if.merge.140 - -while.exit.138: ; preds = %while.hdr.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) - ret { ptr, i64 } %callN - -if.then.139: ; preds = %while.body.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.140 - -if.merge.140: ; preds = %if.then.139, %while.body.137 - %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.363, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 - -fv.default: ; preds = %if.merge.140 - br label %fv.merge - -fv.case: ; preds = %if.merge.140 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.140 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.365, i64 9 }, { ptr, i64 } { ptr @str.366, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.372, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, 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 @@ -4089,27 +3898,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.126 + +fv.default: ; preds = %if.merge.130 + br label %fv.merge + +fv.case: ; preds = %if.merge.130 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.130 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.130 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 10 }, { ptr, i64 } { ptr @str.356, 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.131 + +while.hdr.131: ; preds = %if.merge.135, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.132, label %while.exit.133 + +while.body.132: ; preds = %while.hdr.131 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.134, label %if.merge.135 + +while.exit.133: ; preds = %while.hdr.131 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) + ret { ptr, i64 } %callN + +if.then.134: ; preds = %while.body.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.135 + +if.merge.135: ; preds = %if.then.134, %while.body.132 + %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.359, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 3 }, { ptr, i64 } { ptr @str.362, 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.136 + +while.hdr.136: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.137, label %while.exit.138 + +while.body.137: ; preds = %while.hdr.136 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.139, label %if.merge.140 + +while.exit.138: ; preds = %while.hdr.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) + ret { ptr, i64 } %callN + +if.then.139: ; preds = %while.body.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.140 + +if.merge.140: ; preds = %if.then.139, %while.body.137 + %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.366, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 10 }, { ptr, i64 } { ptr @str.369, 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.141 + +while.hdr.141: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.374, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.141 fv.default: ; preds = %if.merge.145 br label %fv.merge fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.145 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.145 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4119,7 +4128,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.374, i64 5 }, { ptr, i64 } { ptr @str.375, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 5 }, { ptr, i64 } { ptr @str.377, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4138,24 +4147,24 @@ while.body.147: ; preds = %while.hdr.146 while.exit.148: ; preds = %while.hdr.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) ret { ptr, i64 } %callN if.then.149: ; preds = %while.body.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.150 if.merge.150: ; preds = %if.then.149, %while.body.147 %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.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.383, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, 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 @@ -4182,7 +4191,7 @@ fv.default: ; preds = %if.merge.150 fv.case: ; preds = %if.merge.150 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.150 @@ -4194,7 +4203,7 @@ fv.case20: ; preds = %if.merge.150 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4203,7 +4212,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 8 }, { ptr, i64 } { ptr @str.384, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4222,24 +4231,24 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 if.merge.155: ; preds = %if.then.154, %while.body.152 %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.390, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.392, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, 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 @@ -4286,7 +4295,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 17 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 17 }, { ptr, i64 } { ptr @str.395, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4305,24 +4314,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.400, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.402, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4351,7 +4360,7 @@ fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4376,7 +4385,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 7 }, { ptr, i64 } { ptr @str.403, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 7 }, { ptr, i64 } { ptr @str.405, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4395,24 +4404,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.410, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, 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 @@ -4439,7 +4448,7 @@ fv.case: ; preds = %if.merge.165 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 @@ -4454,7 +4463,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 4 }, { ptr, i64 } { ptr @str.411, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 4 }, { ptr, i64 } { ptr @str.413, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4473,24 +4482,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4527,7 +4536,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 10 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 10 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4546,24 +4555,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4629,7 +4638,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 13 }, { ptr, i64 } { ptr @str.429, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 13 }, { ptr, i64 } { ptr @str.431, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4648,24 +4657,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.434, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.436, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4707,7 +4716,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 8 }, { ptr, i64 } { ptr @str.437, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 8 }, { ptr, i64 } { ptr @str.439, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4726,24 +4735,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.445, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.447, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4804,7 +4813,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 5 }, { ptr, i64 } { ptr @str.448, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 5 }, { ptr, i64 } { ptr @str.450, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4823,24 +4832,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.456, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, 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 @@ -4886,7 +4895,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 6 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4905,24 +4914,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.463, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.465, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, 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 @@ -4970,7 +4979,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 6 }, { ptr, i64 } { ptr @str.468, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4989,24 +4998,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.471, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.473, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5050,7 +5059,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 4 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 4 }, { ptr, i64 } { ptr @str.476, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5069,24 +5078,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.482, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5136,7 +5145,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 6 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 6 }, { ptr, i64 } { ptr @str.485, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5155,24 +5164,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5212,7 +5221,7 @@ fv.case20: ; preds = %if.merge.210 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5221,7 +5230,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 12 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 12 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5240,24 +5249,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.495, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.497, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5277,7 +5286,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 8 }, { ptr, i64 } { ptr @str.498, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 8 }, { ptr, i64 } { ptr @str.500, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5296,24 +5305,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.506, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5365,7 +5374,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 7 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 7 }, { ptr, i64 } { ptr @str.509, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5384,24 +5393,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.513, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.515, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5453,7 +5462,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 9 }, { ptr, i64 } { ptr @str.516, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 9 }, { ptr, i64 } { ptr @str.518, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5472,24 +5481,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.521, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.523, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5532,7 +5541,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 4 }, { ptr, i64 } { ptr @str.524, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 4 }, { ptr, i64 } { ptr @str.526, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5551,24 +5560,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.529, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.531, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5614,7 +5623,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 6 }, { ptr, i64 } { ptr @str.532, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.533, i64 6 }, { ptr, i64 } { ptr @str.534, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5633,24 +5642,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.542, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.544, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5732,7 +5741,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.544, i64 6 }, { ptr, i64 } { ptr @str.545, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5751,24 +5760,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5827,9 +5836,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, 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 @@ -5848,8 +5857,8 @@ entry: if.then.253: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 @@ -5868,9 +5877,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, 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 @@ -5889,8 +5898,8 @@ entry: if.then.255: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5920,9 +5929,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.576, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.578, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5939,8 +5948,8 @@ entry: if.then.257: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.258 @@ -6018,9 +6027,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.587, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, 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 @@ -6039,8 +6048,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -6059,9 +6068,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, 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 @@ -6080,8 +6089,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -6098,7 +6107,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.271 @@ -6115,12 +6124,12 @@ while.body.272: ; preds = %while.hdr.271 while.exit.273: ; preds = %while.hdr.271 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %call if.then.274: ; preds = %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.275 @@ -6149,7 +6158,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -6166,12 +6175,12 @@ while.body.277: ; preds = %while.hdr.276 while.exit.278: ; preds = %while.hdr.276 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) ret { ptr, i64 } %call if.then.279: ; preds = %while.body.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6201,7 +6210,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6218,12 +6227,12 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) ret { ptr, i64 } %call if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -6251,7 +6260,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6268,12 +6277,12 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) ret { ptr, i64 } %call if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6302,7 +6311,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6319,12 +6328,12 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) ret { ptr, i64 } %call if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -6353,7 +6362,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6370,12 +6379,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6405,7 +6414,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.308 @@ -6424,12 +6433,12 @@ while.body.309: ; preds = %while.hdr.308 while.exit.310: ; preds = %while.hdr.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) ret { ptr, i64 } %call if.then.311: ; preds = %while.body.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.312 @@ -6458,7 +6467,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6477,12 +6486,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6511,7 +6520,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6530,12 +6539,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6565,7 +6574,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6584,12 +6593,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6619,7 +6628,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.631, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6638,12 +6647,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6685,12 +6694,12 @@ if.then.366: ; preds = %entry if.else.367: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 5 }, { ptr, i64 } %callN) br label %if.merge.368 if.merge.368: ; preds = %if.else.367, %if.then.366 - %bp = phi { ptr, i64 } [ { ptr @str.632, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6713,12 +6722,12 @@ if.then.382: ; preds = %entry if.else.383: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 11 }, { ptr, i64 } %callN) br label %if.merge.384 if.merge.384: ; preds = %if.else.383, %if.then.382 - %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6741,12 +6750,12 @@ if.then.385: ; preds = %entry if.else.386: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 4 }, { ptr, i64 } %callN) br label %if.merge.387 if.merge.387: ; preds = %if.else.386, %if.then.385 - %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6769,12 +6778,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6797,12 +6806,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 6 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6824,12 +6833,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 5 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6852,12 +6861,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 9 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6880,12 +6889,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 18 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6908,12 +6917,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 5 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6936,12 +6945,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6964,12 +6973,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 4 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6992,12 +7001,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 9 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -7020,12 +7029,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -7047,12 +7056,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 8 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7075,12 +7084,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 6 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7102,12 +7111,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 9 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7130,12 +7139,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 7 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7158,12 +7167,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 5 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7186,12 +7195,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7214,12 +7223,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 4 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7242,12 +7251,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7270,12 +7279,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 5 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7298,12 +7307,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7326,12 +7335,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 12 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7354,12 +7363,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 6 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7382,12 +7391,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 4 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7410,12 +7419,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 7 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7438,12 +7447,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 6 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7466,12 +7475,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7494,12 +7503,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 5 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7522,12 +7531,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 4 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7543,7 +7552,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.725, i64 4 } + ret { ptr, i64 } { ptr @str.727, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7567,7 +7576,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.726, i64 4 } + ret { ptr, i64 } { ptr @str.728, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7591,7 +7600,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7615,7 +7624,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.485: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0528-packs-protocol-pack-methods.ir b/examples/expected/0528-packs-protocol-pack-methods.ir index fc7fbc7..6a89003 100644 --- a/examples/expected/0528-packs-protocol-pack-methods.ir +++ b/examples/expected/0528-packs-protocol-pack-methods.ir @@ -1,677 +1,677 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [176 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [8 x i8] c"Greeter\00" -@tn.str.237 = private constant [18 x i8] c"__Greeter__Vtable\00" -@tn.str.238 = private constant [4 x i8] c"Dog\00" -@tn.str.239 = private constant [4 x i8] c"Cat\00" -@tn.str.240 = private constant [5 x i8] c"*Dog\00" -@tn.str.241 = private constant [5 x i8] c"*Cat\00" -@tn.str.242 = private constant [10 x i8] c"[]Greeter\00" -@tn.str.243 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.244 = private constant [7 x i8] c"**void\00" -@tn.str.245 = private constant [6 x i8] c"[]Any\00" -@tn.str.246 = private constant [5 x i8] c"*Any\00" -@tn.str.247 = private constant [7 x i8] c"[2]Any\00" -@tn.str.248 = private constant [8 x i8] c"*[2]Any\00" -@tn.str.249 = private constant [7 x i8] c"*[]Any\00" -@tn.str.250 = private constant [6 x i8] c"**Dog\00" -@tn.str.251 = private constant [6 x i8] c"**Cat\00" -@tn.str.252 = private constant [8 x i8] c"*string\00" -@tn.str.253 = private constant [7 x i8] c"[1]Any\00" -@tn.str.254 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.255 = private constant [6 x i8] c"*bool\00" -@tn.str.256 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.257 = private constant [5 x i8] c"*f64\00" -@tn.str.258 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.259 = private constant [11 x i8] c"*Allocator\00" -@tn.str.260 = private constant [9 x i8] c"*Context\00" -@tn.str.261 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.262 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.263 = private constant [8 x i8] c"*Member\00" -@tn.str.264 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.265 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.266 = private constant [9 x i8] c"*Command\00" -@tn.str.267 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.268 = private constant [9 x i8] c"*Greeter\00" -@tn.str.269 = private constant [19 x i8] c"*__Greeter__Vtable\00" -@tn.str.270 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.271 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.272 = private constant [7 x i8] c"*Value\00" -@tn.str.273 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.274 = private constant [14 x i8] c"*Architecture\00" -@tn.str.275 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.276 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.277 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.278 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.279 = private constant [10 x i8] c"*[]string\00" -@tn.str.280 = private constant [6 x i8] c"*[]u8\00" -@tn.str.281 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.282 = private constant [11 x i8] c"*[]Command\00" -@tn.str.283 = private constant [11 x i8] c"*[]Greeter\00" -@tn.str.284 = private constant [6 x i8] c"**GPA\00" -@tn.str.285 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.286 = private constant [8 x i8] c"**Arena\00" -@tn.str.287 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.288 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.289 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.290 = private constant [7 x i8] c"**File\00" -@tn.str.291 = private constant [5 x i8] c"**u8\00" -@tn.str.292 = private constant [6 x i8] c"**s32\00" -@tn.str.293 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.294 = private constant [6 x i8] c"**u32\00" -@tn.str.295 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.296 = private constant [8 x i8] c"**Array\00" -@tn.str.297 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.298 = private constant [9 x i8] c"**Object\00" -@tn.str.299 = private constant [7 x i8] c"**Sink\00" -@tn.str.300 = private constant [9 x i8] c"**Parser\00" -@tn.str.301 = private constant [6 x i8] c"**s64\00" -@tn.str.302 = private constant [9 x i8] c"**Parsed\00" -@tn.str.303 = private constant [7 x i8] c"**Diag\00" -@tn.str.304 = private constant [9 x i8] c"**Sha256\00" -@tn.str.305 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.306 = private constant [8 x i8] c"***void\00" -@tn.str.307 = private constant [6 x i8] c"**Any\00" -@tn.str.308 = private constant [9 x i8] c"**[2]Any\00" -@tn.str.309 = private constant [8 x i8] c"**[]Any\00" -@tn.str.310 = private constant [7 x i8] c"***Dog\00" -@tn.str.311 = private constant [7 x i8] c"***Cat\00" -@tn.str.312 = private constant [9 x i8] c"**string\00" -@tn.str.313 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.314 = private constant [7 x i8] c"**bool\00" -@tn.str.315 = private constant [7 x i8] c"*?File\00" -@tn.str.316 = private constant [9 x i8] c"*?string\00" -@tn.str.317 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.318 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [176 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 17 }, { ptr, i64 } { ptr @tn.str.238, i64 3 }, { ptr, i64 } { ptr @tn.str.239, i64 3 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 9 }, { ptr, i64 } { ptr @tn.str.243, i64 12 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 5 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 6 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 5 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 4 }, { ptr, i64 } { ptr @tn.str.258, i64 16 }, { ptr, i64 } { ptr @tn.str.259, i64 10 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 11 }, { ptr, i64 } { ptr @tn.str.262, i64 14 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 13 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 8 }, { ptr, i64 } { ptr @tn.str.267, i64 10 }, { ptr, i64 } { ptr @tn.str.268, i64 8 }, { ptr, i64 } { ptr @tn.str.269, i64 18 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 9 }, { ptr, i64 } { ptr @tn.str.272, i64 6 }, { ptr, i64 } { ptr @tn.str.273, i64 16 }, { ptr, i64 } { ptr @tn.str.274, i64 13 }, { ptr, i64 } { ptr @tn.str.275, i64 14 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 7 }, { ptr, i64 } { ptr @tn.str.278, i64 8 }, { ptr, i64 } { ptr @tn.str.279, i64 9 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 11 }, { ptr, i64 } { ptr @tn.str.282, i64 10 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 12 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 10 }, { ptr, i64 } { ptr @tn.str.289, i64 19 }, { ptr, i64 } { ptr @tn.str.290, i64 6 }, { ptr, i64 } { ptr @tn.str.291, i64 4 }, { ptr, i64 } { ptr @tn.str.292, i64 5 }, { ptr, i64 } { ptr @tn.str.293, i64 10 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 9 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 10 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 6 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 13 }, { ptr, i64 } { ptr @tn.str.306, i64 7 }, { ptr, i64 } { ptr @tn.str.307, i64 5 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 7 }, { ptr, i64 } { ptr @tn.str.310, i64 6 }, { ptr, i64 } { ptr @tn.str.311, i64 6 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 8 }, { ptr, i64 } { ptr @tn.str.314, i64 6 }, { ptr, i64 } { ptr @tn.str.315, i64 6 }, { ptr, i64 } { ptr @tn.str.316, i64 8 }, { ptr, i64 } { ptr @tn.str.317, i64 15 }, { ptr, i64 } { ptr @tn.str.318, i64 8 }] -@str.319 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.320 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [8 x i8] c"Greeter\00" +@tn.str.239 = private constant [18 x i8] c"__Greeter__Vtable\00" +@tn.str.240 = private constant [4 x i8] c"Dog\00" +@tn.str.241 = private constant [4 x i8] c"Cat\00" +@tn.str.242 = private constant [5 x i8] c"*Dog\00" +@tn.str.243 = private constant [5 x i8] c"*Cat\00" +@tn.str.244 = private constant [10 x i8] c"[]Greeter\00" +@tn.str.245 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.246 = private constant [7 x i8] c"**void\00" +@tn.str.247 = private constant [6 x i8] c"[]Any\00" +@tn.str.248 = private constant [5 x i8] c"*Any\00" +@tn.str.249 = private constant [7 x i8] c"[2]Any\00" +@tn.str.250 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.251 = private constant [7 x i8] c"*[]Any\00" +@tn.str.252 = private constant [6 x i8] c"**Dog\00" +@tn.str.253 = private constant [6 x i8] c"**Cat\00" +@tn.str.254 = private constant [8 x i8] c"*string\00" +@tn.str.255 = private constant [7 x i8] c"[1]Any\00" +@tn.str.256 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.257 = private constant [6 x i8] c"*bool\00" +@tn.str.258 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.259 = private constant [5 x i8] c"*f64\00" +@tn.str.260 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.261 = private constant [11 x i8] c"*Allocator\00" +@tn.str.262 = private constant [9 x i8] c"*Context\00" +@tn.str.263 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.264 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.265 = private constant [8 x i8] c"*Member\00" +@tn.str.266 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.267 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.268 = private constant [9 x i8] c"*Command\00" +@tn.str.269 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.270 = private constant [9 x i8] c"*Greeter\00" +@tn.str.271 = private constant [19 x i8] c"*__Greeter__Vtable\00" +@tn.str.272 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.273 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.274 = private constant [7 x i8] c"*Value\00" +@tn.str.275 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.276 = private constant [14 x i8] c"*Architecture\00" +@tn.str.277 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.278 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.279 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.280 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.281 = private constant [10 x i8] c"*[]string\00" +@tn.str.282 = private constant [6 x i8] c"*[]u8\00" +@tn.str.283 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.284 = private constant [11 x i8] c"*[]Command\00" +@tn.str.285 = private constant [11 x i8] c"*[]Greeter\00" +@tn.str.286 = private constant [6 x i8] c"**GPA\00" +@tn.str.287 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.288 = private constant [8 x i8] c"**Arena\00" +@tn.str.289 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.290 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.291 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.292 = private constant [7 x i8] c"**File\00" +@tn.str.293 = private constant [5 x i8] c"**u8\00" +@tn.str.294 = private constant [6 x i8] c"**s32\00" +@tn.str.295 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.296 = private constant [6 x i8] c"**u32\00" +@tn.str.297 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.298 = private constant [8 x i8] c"**Array\00" +@tn.str.299 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.300 = private constant [9 x i8] c"**Object\00" +@tn.str.301 = private constant [7 x i8] c"**Sink\00" +@tn.str.302 = private constant [9 x i8] c"**Parser\00" +@tn.str.303 = private constant [6 x i8] c"**s64\00" +@tn.str.304 = private constant [9 x i8] c"**Parsed\00" +@tn.str.305 = private constant [7 x i8] c"**Diag\00" +@tn.str.306 = private constant [9 x i8] c"**Sha256\00" +@tn.str.307 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.308 = private constant [8 x i8] c"***void\00" +@tn.str.309 = private constant [6 x i8] c"**Any\00" +@tn.str.310 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.311 = private constant [8 x i8] c"**[]Any\00" +@tn.str.312 = private constant [7 x i8] c"***Dog\00" +@tn.str.313 = private constant [7 x i8] c"***Cat\00" +@tn.str.314 = private constant [9 x i8] c"**string\00" +@tn.str.315 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.316 = private constant [7 x i8] c"**bool\00" +@tn.str.317 = private constant [7 x i8] c"*?File\00" +@tn.str.318 = private constant [9 x i8] c"*?string\00" +@tn.str.319 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.320 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [176 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 17 }, { ptr, i64 } { ptr @tn.str.240, i64 3 }, { ptr, i64 } { ptr @tn.str.241, i64 3 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 9 }, { ptr, i64 } { ptr @tn.str.245, i64 12 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 5 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 5 }, { ptr, i64 } { ptr @tn.str.253, i64 5 }, { ptr, i64 } { ptr @tn.str.254, i64 7 }, { ptr, i64 } { ptr @tn.str.255, i64 6 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 5 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 4 }, { ptr, i64 } { ptr @tn.str.260, i64 16 }, { ptr, i64 } { ptr @tn.str.261, i64 10 }, { ptr, i64 } { ptr @tn.str.262, i64 8 }, { ptr, i64 } { ptr @tn.str.263, i64 11 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 13 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 8 }, { ptr, i64 } { ptr @tn.str.269, i64 10 }, { ptr, i64 } { ptr @tn.str.270, i64 8 }, { ptr, i64 } { ptr @tn.str.271, i64 18 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 9 }, { ptr, i64 } { ptr @tn.str.274, i64 6 }, { ptr, i64 } { ptr @tn.str.275, i64 16 }, { ptr, i64 } { ptr @tn.str.276, i64 13 }, { ptr, i64 } { ptr @tn.str.277, i64 14 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 7 }, { ptr, i64 } { ptr @tn.str.280, i64 8 }, { ptr, i64 } { ptr @tn.str.281, i64 9 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 11 }, { ptr, i64 } { ptr @tn.str.284, i64 10 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 12 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 10 }, { ptr, i64 } { ptr @tn.str.291, i64 19 }, { ptr, i64 } { ptr @tn.str.292, i64 6 }, { ptr, i64 } { ptr @tn.str.293, i64 4 }, { ptr, i64 } { ptr @tn.str.294, i64 5 }, { ptr, i64 } { ptr @tn.str.295, i64 10 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 9 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 10 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 13 }, { ptr, i64 } { ptr @tn.str.308, i64 7 }, { ptr, i64 } { ptr @tn.str.309, i64 5 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }, { ptr, i64 } { ptr @tn.str.311, i64 7 }, { ptr, i64 } { ptr @tn.str.312, i64 6 }, { ptr, i64 } { ptr @tn.str.313, i64 6 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { ptr, i64 } { ptr @tn.str.315, i64 8 }, { ptr, i64 } { ptr @tn.str.316, i64 6 }, { ptr, i64 } { ptr @tn.str.317, i64 6 }, { ptr, i64 } { ptr @tn.str.318, i64 8 }, { ptr, i64 } { ptr @tn.str.319, i64 15 }, { ptr, i64 } { ptr @tn.str.320, i64 8 }] @str.321 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.322 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.323 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.324 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.325 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.326 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.327 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.328 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.329 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.330 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.331 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.332 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.333 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.334 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.335 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.336 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.337 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.338 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.339 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.340 = private unnamed_addr constant [12 x i8] c"dog+cat={}\0A\00", align 1 -@str.341 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.325 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.326 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.327 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.328 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.329 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.330 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.331 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.332 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.333 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.334 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.335 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.336 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.337 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.338 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.339 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.340 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.341 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.342 = private unnamed_addr constant [12 x i8] c"dog+cat={}\0A\00", align 1 -@str.343 = private unnamed_addr constant [12 x i8] c"cat+dog={}\0A\00", align 1 -@str.344 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.343 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.344 = private unnamed_addr constant [12 x i8] c"dog+cat={}\0A\00", align 1 @str.345 = private unnamed_addr constant [12 x i8] c"cat+dog={}\0A\00", align 1 -@str.346 = private unnamed_addr constant [12 x i8] c"dog+dog={}\0A\00", align 1 -@str.347 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.346 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.347 = private unnamed_addr constant [12 x i8] c"cat+dog={}\0A\00", align 1 @str.348 = private unnamed_addr constant [12 x i8] c"dog+dog={}\0A\00", align 1 -@str.349 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.350 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.352 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.349 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.350 = private unnamed_addr constant [12 x i8] c"dog+dog={}\0A\00", align 1 +@str.351 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.353 = private constant [5 x i8] c"line\00" -@fld.str.354 = private constant [4 x i8] c"col\00" -@fld.str.355 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.353, i64 4 }, { ptr, i64 } { ptr @fld.str.354, i64 3 }, { ptr, i64 } { ptr @fld.str.355, i64 4 }] -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.361 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.362 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.363 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.364 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.366 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.367 = private constant [12 x i8] c"alloc_count\00" -@field_names.368 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.367, i64 11 }] -@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.370 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.371 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.372 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.374 = private constant [5 x i8] c"next\00" -@fld.str.375 = private constant [4 x i8] c"cap\00" -@field_names.376 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 4 }, { ptr, i64 } { ptr @fld.str.375, i64 3 }] -@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.378 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.379 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.380 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.381 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.382 = private constant [4 x i8] c"ctx\00" -@fld.str.383 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.384 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.385 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 3 }, { ptr, i64 } { ptr @fld.str.383, i64 11 }, { ptr, i64 } { ptr @fld.str.384, i64 13 }] -@str.386 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.387 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.388 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.389 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.390 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.391 = private constant [6 x i8] c"first\00" -@fld.str.392 = private constant [10 x i8] c"end_index\00" -@fld.str.393 = private constant [7 x i8] c"parent\00" -@field_names.394 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.391, i64 5 }, { ptr, i64 } { ptr @fld.str.392, i64 9 }, { ptr, i64 } { ptr @fld.str.393, i64 6 }] -@str.395 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.396 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.397 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.398 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.399 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.400 = private constant [4 x i8] c"buf\00" -@fld.str.401 = private constant [4 x i8] c"len\00" -@fld.str.402 = private constant [4 x i8] c"pos\00" -@field_names.403 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.400, i64 3 }, { ptr, i64 } { ptr @fld.str.401, i64 3 }, { ptr, i64 } { ptr @fld.str.402, i64 3 }] -@str.404 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.405 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.406 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.407 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.408 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.409 = private constant [7 x i8] c"parent\00" -@fld.str.410 = private constant [12 x i8] c"alloc_count\00" -@fld.str.411 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.412 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.413 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.409, i64 6 }, { ptr, i64 } { ptr @fld.str.410, i64 11 }, { ptr, i64 } { ptr @fld.str.411, i64 13 }, { ptr, i64 } { ptr @fld.str.412, i64 17 }] -@str.414 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.415 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.416 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.417 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.418 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.419 = private constant [10 x i8] c"allocator\00" -@fld.str.420 = private constant [5 x i8] c"data\00" -@field_names.421 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.419, i64 9 }, { ptr, i64 } { ptr @fld.str.420, i64 4 }] -@str.422 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.423 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.424 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.425 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.426 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.427 = private constant [3 x i8] c"fd\00" -@field_names.428 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.427, i64 2 }] -@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.430 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.434 = private constant [5 x i8] c"file\00" -@fld.str.435 = private constant [5 x i8] c"line\00" -@fld.str.436 = private constant [4 x i8] c"col\00" -@fld.str.437 = private constant [5 x i8] c"func\00" -@fld.str.438 = private constant [10 x i8] c"line_text\00" -@field_names.439 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 4 }, { ptr, i64 } { ptr @fld.str.435, i64 4 }, { ptr, i64 } { ptr @fld.str.436, i64 3 }, { ptr, i64 } { ptr @fld.str.437, i64 4 }, { ptr, i64 } { ptr @fld.str.438, i64 9 }] -@str.440 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.441 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.442 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.443 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.444 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.445 = private constant [10 x i8] c"exit_code\00" -@fld.str.446 = private constant [7 x i8] c"stdout\00" -@field_names.447 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.445, i64 9 }, { ptr, i64 } { ptr @fld.str.446, i64 6 }] -@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.449 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.453 = private constant [8 x i8] c"sin_len\00" -@fld.str.454 = private constant [11 x i8] c"sin_family\00" -@fld.str.455 = private constant [9 x i8] c"sin_port\00" -@fld.str.456 = private constant [9 x i8] c"sin_addr\00" -@fld.str.457 = private constant [9 x i8] c"sin_zero\00" -@field_names.458 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 7 }, { ptr, i64 } { ptr @fld.str.454, i64 10 }, { ptr, i64 } { ptr @fld.str.455, i64 8 }, { ptr, i64 } { ptr @fld.str.456, i64 8 }, { ptr, i64 } { ptr @fld.str.457, i64 8 }] -@str.459 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.460 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.461 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.462 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.463 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.464 = private constant [6 x i8] c"items\00" -@fld.str.465 = private constant [4 x i8] c"len\00" -@fld.str.466 = private constant [4 x i8] c"cap\00" -@field_names.467 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.464, i64 5 }, { ptr, i64 } { ptr @fld.str.465, i64 3 }, { ptr, i64 } { ptr @fld.str.466, i64 3 }] -@str.468 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.469 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.470 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.471 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.472 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.473 = private constant [6 x i8] c"items\00" -@fld.str.474 = private constant [4 x i8] c"len\00" -@fld.str.475 = private constant [4 x i8] c"cap\00" -@field_names.476 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.473, i64 5 }, { ptr, i64 } { ptr @fld.str.474, i64 3 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }] -@str.477 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.478 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.479 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.480 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.481 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.482 = private constant [4 x i8] c"key\00" -@fld.str.483 = private constant [4 x i8] c"val\00" -@field_names.484 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 3 }] -@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.486 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.487 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.488 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.489 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.490 = private constant [4 x i8] c"dst\00" -@fld.str.491 = private constant [4 x i8] c"pos\00" -@fld.str.492 = private constant [5 x i8] c"file\00" -@field_names.493 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.490, i64 3 }, { ptr, i64 } { ptr @fld.str.491, i64 3 }, { ptr, i64 } { ptr @fld.str.492, i64 4 }] -@str.494 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.495 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.496 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.497 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.498 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.499 = private constant [4 x i8] c"src\00" -@fld.str.500 = private constant [4 x i8] c"pos\00" -@fld.str.501 = private constant [6 x i8] c"alloc\00" -@field_names.502 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.499, i64 3 }, { ptr, i64 } { ptr @fld.str.500, i64 3 }, { ptr, i64 } { ptr @fld.str.501, i64 5 }] -@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.504 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.505 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.507 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.508 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.510 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.514 = private constant [5 x i8] c"name\00" -@fld.str.515 = private constant [12 x i8] c"takes_value\00" -@fld.str.516 = private constant [9 x i8] c"required\00" -@field_names.517 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 4 }, { ptr, i64 } { ptr @fld.str.515, i64 11 }, { ptr, i64 } { ptr @fld.str.516, i64 8 }] -@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.519 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.523 = private constant [6 x i8] c"group\00" -@fld.str.524 = private constant [8 x i8] c"command\00" -@fld.str.525 = private constant [6 x i8] c"flags\00" -@field_names.526 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 5 }, { ptr, i64 } { ptr @fld.str.524, i64 7 }, { ptr, i64 } { ptr @fld.str.525, i64 5 }] -@str.527 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.528 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.529 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.530 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.531 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.532 = private constant [4 x i8] c"set\00" -@fld.str.533 = private constant [6 x i8] c"value\00" -@field_names.534 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.532, i64 3 }, { ptr, i64 } { ptr @fld.str.533, i64 5 }] -@str.535 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.536 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.537 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.539 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.540 = private constant [6 x i8] c"index\00" -@fld.str.541 = private constant [6 x i8] c"token\00" -@field_names.542 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.540, i64 5 }, { ptr, i64 } { ptr @fld.str.541, i64 5 }] -@str.543 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.544 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.547 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.548 = private constant [6 x i8] c"group\00" -@fld.str.549 = private constant [8 x i8] c"command\00" -@fld.str.550 = private constant [10 x i8] c"cmd_index\00" -@fld.str.551 = private constant [5 x i8] c"json\00" -@fld.str.552 = private constant [5 x i8] c"rest\00" -@fld.str.553 = private constant [5 x i8] c"spec\00" -@fld.str.554 = private constant [7 x i8] c"values\00" -@field_names.555 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 5 }, { ptr, i64 } { ptr @fld.str.549, i64 7 }, { ptr, i64 } { ptr @fld.str.550, i64 9 }, { ptr, i64 } { ptr @fld.str.551, i64 4 }, { ptr, i64 } { ptr @fld.str.552, i64 4 }, { ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 6 }] -@str.556 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.557 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.558 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.559 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.560 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.561 = private constant [2 x i8] c"h\00" -@fld.str.562 = private constant [4 x i8] c"buf\00" -@fld.str.563 = private constant [8 x i8] c"buf_len\00" -@fld.str.564 = private constant [10 x i8] c"total_len\00" -@field_names.565 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.561, i64 1 }, { ptr, i64 } { ptr @fld.str.562, i64 3 }, { ptr, i64 } { ptr @fld.str.563, i64 7 }, { ptr, i64 } { ptr @fld.str.564, i64 9 }] -@str.566 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.567 = private unnamed_addr constant [8 x i8] c"Greeter\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.570 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.571 = private constant [4 x i8] c"ctx\00" -@fld.str.572 = private constant [9 x i8] c"__vtable\00" -@field_names.573 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.571, i64 3 }, { ptr, i64 } { ptr @fld.str.572, i64 8 }] -@str.574 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.575 = private unnamed_addr constant [18 x i8] c"__Greeter__Vtable\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.578 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.579 = private constant [6 x i8] c"greet\00" -@field_names.580 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }] -@str.581 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.582 = private unnamed_addr constant [4 x i8] c"Dog\00", align 1 -@str.583 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.584 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.585 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.586 = private constant [4 x i8] c"age\00" -@field_names.587 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.586, i64 3 }] -@str.588 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.589 = private unnamed_addr constant [4 x i8] c"Cat\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.592 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.593 = private constant [6 x i8] c"lives\00" -@field_names.594 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 5 }] -@str.595 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.597 = private constant [5 x i8] c"read\00" -@fld.str.598 = private constant [6 x i8] c"write\00" -@fld.str.599 = private constant [7 x i8] c"append\00" -@fld.str.600 = private constant [11 x i8] c"read_write\00" -@field_names.601 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.597, i64 4 }, { ptr, i64 } { ptr @fld.str.598, i64 5 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 10 }] -@str.602 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.605 = private constant [4 x i8] c"set\00" -@fld.str.606 = private constant [8 x i8] c"current\00" -@fld.str.607 = private constant [4 x i8] c"end\00" -@field_names.608 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.605, i64 3 }, { ptr, i64 } { ptr @fld.str.606, i64 7 }, { ptr, i64 } { ptr @fld.str.607, i64 3 }] -@str.609 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.612 = private constant [6 x i8] c"null_\00" -@fld.str.613 = private constant [6 x i8] c"bool_\00" -@fld.str.614 = private constant [5 x i8] c"int_\00" -@fld.str.615 = private constant [4 x i8] c"str\00" -@fld.str.616 = private constant [6 x i8] c"array\00" -@fld.str.617 = private constant [7 x i8] c"object\00" -@field_names.618 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.612, i64 5 }, { ptr, i64 } { ptr @fld.str.613, i64 5 }, { ptr, i64 } { ptr @fld.str.614, i64 4 }, { ptr, i64 } { ptr @fld.str.615, i64 3 }, { ptr, i64 } { ptr @fld.str.616, i64 5 }, { ptr, i64 } { ptr @fld.str.617, i64 6 }] -@str.619 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.622 = private constant [6 x i8] c"macos\00" -@fld.str.623 = private constant [6 x i8] c"linux\00" -@fld.str.624 = private constant [8 x i8] c"windows\00" -@fld.str.625 = private constant [5 x i8] c"wasm\00" -@fld.str.626 = private constant [4 x i8] c"ios\00" -@fld.str.627 = private constant [8 x i8] c"android\00" -@fld.str.628 = private constant [8 x i8] c"unknown\00" -@field_names.629 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.622, i64 5 }, { ptr, i64 } { ptr @fld.str.623, i64 5 }, { ptr, i64 } { ptr @fld.str.624, i64 7 }, { ptr, i64 } { ptr @fld.str.625, i64 4 }, { ptr, i64 } { ptr @fld.str.626, i64 3 }, { ptr, i64 } { ptr @fld.str.627, i64 7 }, { ptr, i64 } { ptr @fld.str.628, i64 7 }] -@str.630 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.633 = private constant [8 x i8] c"aarch64\00" -@fld.str.634 = private constant [7 x i8] c"x86_64\00" -@fld.str.635 = private constant [7 x i8] c"wasm32\00" -@fld.str.636 = private constant [7 x i8] c"wasm64\00" -@fld.str.637 = private constant [8 x i8] c"unknown\00" -@field_names.638 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.633, i64 7 }, { ptr, i64 } { ptr @fld.str.634, i64 6 }, { ptr, i64 } { ptr @fld.str.635, i64 6 }, { ptr, i64 } { ptr @fld.str.636, i64 6 }, { ptr, i64 } { ptr @fld.str.637, i64 7 }] -@str.639 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.640 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.641 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.642 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.643 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.644 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.645 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.646 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.647 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.648 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.649 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.650 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.651 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.652 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.653 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.654 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.655 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.656 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.657 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.658 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.659 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.660 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.661 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.662 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.663 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.664 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.665 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.668 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.669 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.670 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.671 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.672 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.673 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.674 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.677 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.678 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.679 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.681 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.684 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.687 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.690 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.693 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.696 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.723 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.726 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.729 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.732 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.735 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.738 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.741 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.742 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.744 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.745 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.747 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.750 = private unnamed_addr constant [5 x i8] c"*Dog\00", align 1 -@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.753 = private unnamed_addr constant [5 x i8] c"*Cat\00", align 1 -@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.756 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.759 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.762 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.765 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 -@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.768 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.771 = private unnamed_addr constant [6 x i8] c"**Dog\00", align 1 -@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.774 = private unnamed_addr constant [6 x i8] c"**Cat\00", align 1 -@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.777 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.780 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.783 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.355 = private constant [5 x i8] c"line\00" +@fld.str.356 = private constant [4 x i8] c"col\00" +@fld.str.357 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.355, i64 4 }, { ptr, i64 } { ptr @fld.str.356, i64 3 }, { ptr, i64 } { ptr @fld.str.357, i64 4 }] +@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.359 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.360 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.361 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.363 = private constant [4 x i8] c"ctx\00" +@fld.str.364 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.365 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.366 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.363, i64 3 }, { ptr, i64 } { ptr @fld.str.364, i64 11 }, { ptr, i64 } { ptr @fld.str.365, i64 13 }] +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.372 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.373 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.374 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.375 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.377 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.378 = private constant [12 x i8] c"alloc_count\00" +@field_names.379 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.378, i64 11 }] +@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.381 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.385 = private constant [5 x i8] c"next\00" +@fld.str.386 = private constant [4 x i8] c"cap\00" +@field_names.387 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 4 }, { ptr, i64 } { ptr @fld.str.386, i64 3 }] +@str.388 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.389 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.390 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.392 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.393 = private constant [6 x i8] c"first\00" +@fld.str.394 = private constant [10 x i8] c"end_index\00" +@fld.str.395 = private constant [7 x i8] c"parent\00" +@field_names.396 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.393, i64 5 }, { ptr, i64 } { ptr @fld.str.394, i64 9 }, { ptr, i64 } { ptr @fld.str.395, i64 6 }] +@str.397 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.398 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.399 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.401 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.402 = private constant [4 x i8] c"buf\00" +@fld.str.403 = private constant [4 x i8] c"len\00" +@fld.str.404 = private constant [4 x i8] c"pos\00" +@field_names.405 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.402, i64 3 }, { ptr, i64 } { ptr @fld.str.403, i64 3 }, { ptr, i64 } { ptr @fld.str.404, i64 3 }] +@str.406 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.407 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.408 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.409 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.410 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.411 = private constant [7 x i8] c"parent\00" +@fld.str.412 = private constant [12 x i8] c"alloc_count\00" +@fld.str.413 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.414 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.415 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.411, i64 6 }, { ptr, i64 } { ptr @fld.str.412, i64 11 }, { ptr, i64 } { ptr @fld.str.413, i64 13 }, { ptr, i64 } { ptr @fld.str.414, i64 17 }] +@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.417 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.421 = private constant [10 x i8] c"allocator\00" +@fld.str.422 = private constant [5 x i8] c"data\00" +@field_names.423 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 9 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }] +@str.424 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.425 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.426 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.427 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.428 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.429 = private constant [3 x i8] c"fd\00" +@field_names.430 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.429, i64 2 }] +@str.431 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.432 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.433 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.434 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.435 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.436 = private constant [5 x i8] c"file\00" +@fld.str.437 = private constant [5 x i8] c"line\00" +@fld.str.438 = private constant [4 x i8] c"col\00" +@fld.str.439 = private constant [5 x i8] c"func\00" +@fld.str.440 = private constant [10 x i8] c"line_text\00" +@field_names.441 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.436, i64 4 }, { ptr, i64 } { ptr @fld.str.437, i64 4 }, { ptr, i64 } { ptr @fld.str.438, i64 3 }, { ptr, i64 } { ptr @fld.str.439, i64 4 }, { ptr, i64 } { ptr @fld.str.440, i64 9 }] +@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.443 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.447 = private constant [10 x i8] c"exit_code\00" +@fld.str.448 = private constant [7 x i8] c"stdout\00" +@field_names.449 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 9 }, { ptr, i64 } { ptr @fld.str.448, i64 6 }] +@str.450 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.451 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.452 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.454 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.455 = private constant [8 x i8] c"sin_len\00" +@fld.str.456 = private constant [11 x i8] c"sin_family\00" +@fld.str.457 = private constant [9 x i8] c"sin_port\00" +@fld.str.458 = private constant [9 x i8] c"sin_addr\00" +@fld.str.459 = private constant [9 x i8] c"sin_zero\00" +@field_names.460 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.455, i64 7 }, { ptr, i64 } { ptr @fld.str.456, i64 10 }, { ptr, i64 } { ptr @fld.str.457, i64 8 }, { ptr, i64 } { ptr @fld.str.458, i64 8 }, { ptr, i64 } { ptr @fld.str.459, i64 8 }] +@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.462 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.463 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.464 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.465 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.466 = private constant [6 x i8] c"items\00" +@fld.str.467 = private constant [4 x i8] c"len\00" +@fld.str.468 = private constant [4 x i8] c"cap\00" +@field_names.469 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.466, i64 5 }, { ptr, i64 } { ptr @fld.str.467, i64 3 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }] +@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.471 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.475 = private constant [6 x i8] c"items\00" +@fld.str.476 = private constant [4 x i8] c"len\00" +@fld.str.477 = private constant [4 x i8] c"cap\00" +@field_names.478 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 5 }, { ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }] +@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.480 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.484 = private constant [4 x i8] c"key\00" +@fld.str.485 = private constant [4 x i8] c"val\00" +@field_names.486 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }] +@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.488 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.489 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.490 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.491 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.492 = private constant [4 x i8] c"dst\00" +@fld.str.493 = private constant [4 x i8] c"pos\00" +@fld.str.494 = private constant [5 x i8] c"file\00" +@field_names.495 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.492, i64 3 }, { ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 4 }] +@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.497 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.501 = private constant [4 x i8] c"src\00" +@fld.str.502 = private constant [4 x i8] c"pos\00" +@fld.str.503 = private constant [6 x i8] c"alloc\00" +@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 3 }, { ptr, i64 } { ptr @fld.str.502, i64 3 }, { ptr, i64 } { ptr @fld.str.503, i64 5 }] +@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.506 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.510 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.512 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.513 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.514 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.515 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.516 = private constant [5 x i8] c"name\00" +@fld.str.517 = private constant [12 x i8] c"takes_value\00" +@fld.str.518 = private constant [9 x i8] c"required\00" +@field_names.519 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 4 }, { ptr, i64 } { ptr @fld.str.517, i64 11 }, { ptr, i64 } { ptr @fld.str.518, i64 8 }] +@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.521 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.522 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.523 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.524 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.525 = private constant [6 x i8] c"group\00" +@fld.str.526 = private constant [8 x i8] c"command\00" +@fld.str.527 = private constant [6 x i8] c"flags\00" +@field_names.528 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 5 }, { ptr, i64 } { ptr @fld.str.526, i64 7 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] +@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.530 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.534 = private constant [4 x i8] c"set\00" +@fld.str.535 = private constant [6 x i8] c"value\00" +@field_names.536 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 3 }, { ptr, i64 } { ptr @fld.str.535, i64 5 }] +@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.538 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.542 = private constant [6 x i8] c"index\00" +@fld.str.543 = private constant [6 x i8] c"token\00" +@field_names.544 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 5 }, { ptr, i64 } { ptr @fld.str.543, i64 5 }] +@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.546 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.550 = private constant [6 x i8] c"group\00" +@fld.str.551 = private constant [8 x i8] c"command\00" +@fld.str.552 = private constant [10 x i8] c"cmd_index\00" +@fld.str.553 = private constant [5 x i8] c"json\00" +@fld.str.554 = private constant [5 x i8] c"rest\00" +@fld.str.555 = private constant [5 x i8] c"spec\00" +@fld.str.556 = private constant [7 x i8] c"values\00" +@field_names.557 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 5 }, { ptr, i64 } { ptr @fld.str.551, i64 7 }, { ptr, i64 } { ptr @fld.str.552, i64 9 }, { ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 4 }, { ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 6 }] +@str.558 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.559 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.560 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.561 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.562 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.563 = private constant [2 x i8] c"h\00" +@fld.str.564 = private constant [4 x i8] c"buf\00" +@fld.str.565 = private constant [8 x i8] c"buf_len\00" +@fld.str.566 = private constant [10 x i8] c"total_len\00" +@field_names.567 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 1 }, { ptr, i64 } { ptr @fld.str.564, i64 3 }, { ptr, i64 } { ptr @fld.str.565, i64 7 }, { ptr, i64 } { ptr @fld.str.566, i64 9 }] +@str.568 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.569 = private unnamed_addr constant [8 x i8] c"Greeter\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.572 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.573 = private constant [4 x i8] c"ctx\00" +@fld.str.574 = private constant [9 x i8] c"__vtable\00" +@field_names.575 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 8 }] +@str.576 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.577 = private unnamed_addr constant [18 x i8] c"__Greeter__Vtable\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.580 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.581 = private constant [6 x i8] c"greet\00" +@field_names.582 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 5 }] +@str.583 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.584 = private unnamed_addr constant [4 x i8] c"Dog\00", align 1 +@str.585 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.586 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.587 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.588 = private constant [4 x i8] c"age\00" +@field_names.589 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.588, i64 3 }] +@str.590 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.591 = private unnamed_addr constant [4 x i8] c"Cat\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.594 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.595 = private constant [6 x i8] c"lives\00" +@field_names.596 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.595, i64 5 }] +@str.597 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.599 = private constant [5 x i8] c"read\00" +@fld.str.600 = private constant [6 x i8] c"write\00" +@fld.str.601 = private constant [7 x i8] c"append\00" +@fld.str.602 = private constant [11 x i8] c"read_write\00" +@field_names.603 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.599, i64 4 }, { ptr, i64 } { ptr @fld.str.600, i64 5 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 10 }] +@str.604 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.607 = private constant [4 x i8] c"set\00" +@fld.str.608 = private constant [8 x i8] c"current\00" +@fld.str.609 = private constant [4 x i8] c"end\00" +@field_names.610 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.607, i64 3 }, { ptr, i64 } { ptr @fld.str.608, i64 7 }, { ptr, i64 } { ptr @fld.str.609, i64 3 }] +@str.611 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.614 = private constant [6 x i8] c"null_\00" +@fld.str.615 = private constant [6 x i8] c"bool_\00" +@fld.str.616 = private constant [5 x i8] c"int_\00" +@fld.str.617 = private constant [4 x i8] c"str\00" +@fld.str.618 = private constant [6 x i8] c"array\00" +@fld.str.619 = private constant [7 x i8] c"object\00" +@field_names.620 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.614, i64 5 }, { ptr, i64 } { ptr @fld.str.615, i64 5 }, { ptr, i64 } { ptr @fld.str.616, i64 4 }, { ptr, i64 } { ptr @fld.str.617, i64 3 }, { ptr, i64 } { ptr @fld.str.618, i64 5 }, { ptr, i64 } { ptr @fld.str.619, i64 6 }] +@str.621 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.624 = private constant [6 x i8] c"macos\00" +@fld.str.625 = private constant [6 x i8] c"linux\00" +@fld.str.626 = private constant [8 x i8] c"windows\00" +@fld.str.627 = private constant [5 x i8] c"wasm\00" +@fld.str.628 = private constant [4 x i8] c"ios\00" +@fld.str.629 = private constant [8 x i8] c"android\00" +@fld.str.630 = private constant [8 x i8] c"unknown\00" +@field_names.631 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.624, i64 5 }, { ptr, i64 } { ptr @fld.str.625, i64 5 }, { ptr, i64 } { ptr @fld.str.626, i64 7 }, { ptr, i64 } { ptr @fld.str.627, i64 4 }, { ptr, i64 } { ptr @fld.str.628, i64 3 }, { ptr, i64 } { ptr @fld.str.629, i64 7 }, { ptr, i64 } { ptr @fld.str.630, i64 7 }] +@str.632 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.635 = private constant [8 x i8] c"aarch64\00" +@fld.str.636 = private constant [7 x i8] c"x86_64\00" +@fld.str.637 = private constant [7 x i8] c"wasm32\00" +@fld.str.638 = private constant [7 x i8] c"wasm64\00" +@fld.str.639 = private constant [8 x i8] c"unknown\00" +@field_names.640 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.635, i64 7 }, { ptr, i64 } { ptr @fld.str.636, i64 6 }, { ptr, i64 } { ptr @fld.str.637, i64 6 }, { ptr, i64 } { ptr @fld.str.638, i64 6 }, { ptr, i64 } { ptr @fld.str.639, i64 7 }] +@str.641 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.642 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.643 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.644 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.645 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.646 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.647 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.648 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.649 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.650 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.651 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.652 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.653 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.654 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.655 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.656 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.657 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.658 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.659 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.660 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.661 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.662 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.663 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.664 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.665 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.666 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.667 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.669 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.670 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.671 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.672 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.673 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.674 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.675 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.676 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.678 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.679 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.680 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.681 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.683 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.686 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.689 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.692 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.695 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.698 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.728 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.729 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.731 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.732 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.734 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.735 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.737 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.738 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.740 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.741 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.742 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.743 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.744 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.745 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.746 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.747 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.748 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.749 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.750 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.751 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.752 = private unnamed_addr constant [5 x i8] c"*Dog\00", align 1 +@str.753 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.754 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.755 = private unnamed_addr constant [5 x i8] c"*Cat\00", align 1 +@str.756 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.757 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.758 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.759 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.760 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.761 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.762 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.763 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.765 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.766 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.767 = private unnamed_addr constant [8 x i8] c"*[2]Any\00", align 1 +@str.768 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.769 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.770 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.771 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.772 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.773 = private unnamed_addr constant [6 x i8] c"**Dog\00", align 1 +@str.774 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.775 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.776 = private unnamed_addr constant [6 x i8] c"**Cat\00", align 1 +@str.777 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.778 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.779 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.780 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.781 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.782 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.783 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.784 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.785 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.786 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.787 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.790 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -684,6 +684,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -903,7 +906,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1030,7 +1033,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1364,7 +1367,7 @@ entry: br i1 %icmp, label %if.then.409, label %if.merge.410 if.then.409: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.410: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1514,7 +1517,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1540,9 +1543,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1589,9 +1592,9 @@ entry: i64 99, label %match.arm.48 i64 102, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1635,7 +1638,7 @@ match.merge.37: ; preds = %dispatch.merge.524, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1679,9 +1682,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1768,9 +1771,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.370 [ i64 18, label %dispatch.case.371 - i64 21, label %dispatch.case.372 - i64 23, label %dispatch.case.373 - i64 25, label %dispatch.case.374 + i64 22, label %dispatch.case.372 + i64 24, label %dispatch.case.373 + i64 26, label %dispatch.case.374 i64 28, label %dispatch.case.375 i64 29, label %dispatch.case.376 i64 31, label %dispatch.case.377 @@ -1872,7 +1875,7 @@ dispatch.merge.94: ; preds = %dispatch.case.124, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.319, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.321, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1886,32 +1889,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2113,7 +2116,7 @@ dispatch.merge.270: ; preds = %dispatch.case.276, br label %match.merge.37 dispatch.default.271: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.320, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.322, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.270 dispatch.case.272: ; preds = %match.arm.44 @@ -2154,7 +2157,7 @@ dispatch.merge.287: ; preds = %dispatch.case.295, br label %match.merge.37 dispatch.default.288: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.321, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.287 dispatch.case.289: ; preds = %match.arm.47 @@ -2219,7 +2222,7 @@ dispatch.merge.331: ; preds = %dispatch.case.338, br label %match.merge.37 dispatch.default.332: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.322, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.331 dispatch.case.333: ; preds = %match.arm.48 @@ -2276,7 +2279,7 @@ dispatch.merge.369: ; preds = %dispatch.case.405, br label %match.merge.37 dispatch.default.370: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.369 dispatch.case.371: ; preds = %match.arm.49 @@ -2530,7 +2533,7 @@ dispatch.merge.524: ; preds = %dispatch.case.529, br label %match.merge.37 dispatch.default.525: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.524 dispatch.case.526: ; preds = %match.arm.50 @@ -2572,7 +2575,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.325, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2668,7 +2671,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2676,7 +2679,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2686,13 +2689,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2700,7 +2703,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2714,7 +2717,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2722,7 +2725,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2733,7 +2736,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2790,7 +2793,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2798,7 +2801,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2809,7 +2812,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2829,7 +2832,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2837,7 +2840,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, 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 @@ -2848,7 +2851,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2858,64 +2861,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3091,163 +3097,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3445,64 +3454,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3532,97 +3541,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3661,7 +3670,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @Dog.greet(ptr %0, ptr %1) #0 { @@ -3768,7 +3777,7 @@ entry: define internal void @print__ct_sa93836785e55c522__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.340, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.342, i64 11 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3783,7 +3792,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.341, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.343, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -3810,7 +3819,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.342, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.344, i64 11 }) ret { ptr, i64 } %call } @@ -3858,7 +3867,7 @@ entry: define internal void @print__ct_sdcda2f2aa37cf168__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.343, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.345, i64 11 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3873,7 +3882,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.344, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.346, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -3900,7 +3909,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.345, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.347, i64 11 }) ret { ptr, i64 } %call } @@ -3948,7 +3957,7 @@ entry: define internal void @print__ct_s1a602d8c97d1af91__pack_s64(ptr %0, i64 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.346, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.348, i64 11 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3963,7 +3972,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.347, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.349, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -3990,7 +3999,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.348, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.350, i64 11 }) ret { ptr, i64 } %call } @@ -4001,7 +4010,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.349, i64 15 }, { ptr, i64 } { ptr @str.350, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 15 }, { ptr, i64 } { ptr @str.352, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4020,12 +4029,12 @@ while.body.126: ; preds = %while.hdr.125 while.exit.127: ; preds = %while.hdr.125 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) ret { ptr, i64 } %callN if.then.128: ; preds = %while.body.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.129 @@ -4037,7 +4046,7 @@ if.merge.129: ; preds = %if.then.128, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4090,20 +4099,20 @@ fv.case24: ; preds = %if.merge.129 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 10 }, { ptr, i64 } { ptr @str.358, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.359, i64 9 }, { ptr, i64 } { ptr @str.360, 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.130 -while.hdr.130: ; preds = %if.merge.134, %entry +while.hdr.130: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.131, label %while.exit.132 while.body.131: ; preds = %while.hdr.130 @@ -4113,224 +4122,24 @@ while.body.131: ; preds = %while.hdr.130 while.exit.132: ; preds = %while.hdr.130 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 1 }) ret { ptr, i64 } %callN if.then.133: ; preds = %while.body.131 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.134 if.merge.134: ; preds = %if.then.133, %while.body.131 %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.361, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.366, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.130 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.363, i64 3 }, { ptr, i64 } { ptr @str.364, 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.135 - -while.hdr.135: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.136, label %while.exit.137 - -while.body.136: ; preds = %while.hdr.135 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.138, label %if.merge.139 - -while.exit.137: ; preds = %while.hdr.135 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 1 }) - ret { ptr, i64 } %callN - -if.then.138: ; preds = %while.body.136 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.139 - -if.merge.139: ; preds = %if.then.138, %while.body.136 - %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.368, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.135 - -fv.default: ; preds = %if.merge.139 - br label %fv.merge - -fv.case: ; preds = %if.merge.139 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 10 }, { ptr, i64 } { ptr @str.371, 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.140 - -while.hdr.140: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.141, label %while.exit.142 - -while.body.141: ; preds = %while.hdr.140 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.143, label %if.merge.144 - -while.exit.142: ; preds = %while.hdr.140 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 1 }) - ret { ptr, i64 } %callN - -if.then.143: ; preds = %while.body.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.144 - -if.merge.144: ; preds = %if.then.143, %while.body.141 - %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.376, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.140 - -fv.default: ; preds = %if.merge.144 - br label %fv.merge - -fv.case: ; preds = %if.merge.144 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.144 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 9 }, { ptr, i64 } { ptr @str.379, 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.145 - -while.hdr.145: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.146, label %while.exit.147 - -while.body.146: ; preds = %while.hdr.145 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.148, label %if.merge.149 - -while.exit.147: ; preds = %while.hdr.145 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 1 }) - ret { ptr, i64 } %callN - -if.then.148: ; preds = %while.body.146 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.149 - -if.merge.149: ; preds = %if.then.148, %while.body.146 - %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.385, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, 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 @@ -4349,27 +4158,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.130 + +fv.default: ; preds = %if.merge.134 + br label %fv.merge + +fv.case: ; preds = %if.merge.134 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.134 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.134 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 10 }, { ptr, i64 } { ptr @str.369, 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.135 + +while.hdr.135: ; preds = %if.merge.139, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.136, label %while.exit.137 + +while.body.136: ; preds = %while.hdr.135 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.138, label %if.merge.139 + +while.exit.137: ; preds = %while.hdr.135 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.138: ; preds = %while.body.136 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.139 + +if.merge.139: ; preds = %if.then.138, %while.body.136 + %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.372, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.135 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.374, i64 3 }, { ptr, i64 } { ptr @str.375, 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.140 + +while.hdr.140: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.141, label %while.exit.142 + +while.body.141: ; preds = %while.hdr.140 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.143, label %if.merge.144 + +while.exit.142: ; preds = %while.hdr.140 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 1 }) + ret { ptr, i64 } %callN + +if.then.143: ; preds = %while.body.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.144 + +if.merge.144: ; preds = %if.then.143, %while.body.141 + %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.379, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.140 + +fv.default: ; preds = %if.merge.144 + br label %fv.merge + +fv.case: ; preds = %if.merge.144 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 10 }, { ptr, i64 } { ptr @str.382, 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.145 + +while.hdr.145: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.146, label %while.exit.147 + +while.body.146: ; preds = %while.hdr.145 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.148, label %if.merge.149 + +while.exit.147: ; preds = %while.hdr.145 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) + ret { ptr, i64 } %callN + +if.then.148: ; preds = %while.body.146 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.149 + +if.merge.149: ; preds = %if.then.148, %while.body.146 + %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.387, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.145 fv.default: ; preds = %if.merge.149 br label %fv.merge fv.case: ; preds = %if.merge.149 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.149 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.149 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4379,7 +4388,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.387, i64 5 }, { ptr, i64 } { ptr @str.388, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.389, i64 5 }, { ptr, i64 } { ptr @str.390, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4398,24 +4407,24 @@ while.body.151: ; preds = %while.hdr.150 while.exit.152: ; preds = %while.hdr.150 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 1 }) ret { ptr, i64 } %callN if.then.153: ; preds = %while.body.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.154 if.merge.154: ; preds = %if.then.153, %while.body.151 %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.394, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.396, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, 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 @@ -4442,7 +4451,7 @@ fv.default: ; preds = %if.merge.154 fv.case: ; preds = %if.merge.154 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.154 @@ -4454,7 +4463,7 @@ fv.case20: ; preds = %if.merge.154 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4463,7 +4472,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.396, i64 8 }, { ptr, i64 } { ptr @str.397, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 8 }, { ptr, i64 } { ptr @str.399, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4482,24 +4491,24 @@ while.body.156: ; preds = %while.hdr.155 while.exit.157: ; preds = %while.hdr.155 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 1 }) ret { ptr, i64 } %callN if.then.158: ; preds = %while.body.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.159 if.merge.159: ; preds = %if.then.158, %while.body.156 %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.403, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.405, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, 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 @@ -4546,7 +4555,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.405, i64 17 }, { ptr, i64 } { ptr @str.406, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 17 }, { ptr, i64 } { ptr @str.408, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4565,24 +4574,24 @@ while.body.161: ; preds = %while.hdr.160 while.exit.162: ; preds = %while.hdr.160 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 1 }) ret { ptr, i64 } %callN if.then.163: ; preds = %while.body.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.164 if.merge.164: ; preds = %if.then.163, %while.body.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.413, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.415, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4611,7 +4620,7 @@ fv.case: ; preds = %if.merge.164 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.164 @@ -4636,7 +4645,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.415, i64 7 }, { ptr, i64 } { ptr @str.416, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 7 }, { ptr, i64 } { ptr @str.418, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4655,24 +4664,24 @@ while.body.166: ; preds = %while.hdr.165 while.exit.167: ; preds = %while.hdr.165 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) ret { ptr, i64 } %callN if.then.168: ; preds = %while.body.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.169 if.merge.169: ; preds = %if.then.168, %while.body.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.421, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.423, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, 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 @@ -4699,7 +4708,7 @@ fv.case: ; preds = %if.merge.169 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.169 @@ -4714,7 +4723,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.423, i64 4 }, { ptr, i64 } { ptr @str.424, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.425, i64 4 }, { ptr, i64 } { ptr @str.426, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4733,24 +4742,24 @@ while.body.171: ; preds = %while.hdr.170 while.exit.172: ; preds = %while.hdr.170 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 1 }) ret { ptr, i64 } %callN if.then.173: ; preds = %while.body.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.174 if.merge.174: ; preds = %if.then.173, %while.body.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.430, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4787,7 +4796,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 10 }, { ptr, i64 } { ptr @str.431, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.432, i64 10 }, { ptr, i64 } { ptr @str.433, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4806,24 +4815,24 @@ while.body.176: ; preds = %while.hdr.175 while.exit.177: ; preds = %while.hdr.175 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 1 }) ret { ptr, i64 } %callN if.then.178: ; preds = %while.body.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.179 if.merge.179: ; preds = %if.then.178, %while.body.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.439, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.441, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4889,7 +4898,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.441, i64 13 }, { ptr, i64 } { ptr @str.442, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 13 }, { ptr, i64 } { ptr @str.444, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4908,24 +4917,24 @@ while.body.181: ; preds = %while.hdr.180 while.exit.182: ; preds = %while.hdr.180 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) ret { ptr, i64 } %callN if.then.183: ; preds = %while.body.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.184 if.merge.184: ; preds = %if.then.183, %while.body.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.447, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.449, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4967,7 +4976,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 8 }, { ptr, i64 } { ptr @str.450, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.451, i64 8 }, { ptr, i64 } { ptr @str.452, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4986,24 +4995,24 @@ while.body.186: ; preds = %while.hdr.185 while.exit.187: ; preds = %while.hdr.185 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 1 }) ret { ptr, i64 } %callN if.then.188: ; preds = %while.body.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.189 if.merge.189: ; preds = %if.then.188, %while.body.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.458, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.460, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5064,7 +5073,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.460, i64 5 }, { ptr, i64 } { ptr @str.461, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 5 }, { ptr, i64 } { ptr @str.463, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5083,24 +5092,24 @@ while.body.191: ; preds = %while.hdr.190 while.exit.192: ; preds = %while.hdr.190 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 1 }) ret { ptr, i64 } %callN if.then.193: ; preds = %while.body.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.194 if.merge.194: ; preds = %if.then.193, %while.body.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.467, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.469, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, 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 @@ -5146,7 +5155,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.469, i64 6 }, { ptr, i64 } { ptr @str.470, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 6 }, { ptr, i64 } { ptr @str.472, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5165,24 +5174,24 @@ while.body.196: ; preds = %while.hdr.195 while.exit.197: ; preds = %while.hdr.195 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) ret { ptr, i64 } %callN if.then.198: ; preds = %while.body.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.199 if.merge.199: ; preds = %if.then.198, %while.body.196 %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.476, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.478, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, 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 @@ -5230,7 +5239,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.478, i64 6 }, { ptr, i64 } { ptr @str.479, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 6 }, { ptr, i64 } { ptr @str.481, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5249,24 +5258,24 @@ while.body.201: ; preds = %while.hdr.200 while.exit.202: ; preds = %while.hdr.200 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) ret { ptr, i64 } %callN if.then.203: ; preds = %while.body.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.204 if.merge.204: ; preds = %if.then.203, %while.body.201 %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.484, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.486, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5310,7 +5319,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 4 }, { ptr, i64 } { ptr @str.487, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 4 }, { ptr, i64 } { ptr @str.489, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5329,24 +5338,24 @@ while.body.206: ; preds = %while.hdr.205 while.exit.207: ; preds = %while.hdr.205 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 1 }) ret { ptr, i64 } %callN if.then.208: ; preds = %while.body.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.209 if.merge.209: ; preds = %if.then.208, %while.body.206 %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.493, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.495, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5396,7 +5405,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 6 }, { ptr, i64 } { ptr @str.496, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 6 }, { ptr, i64 } { ptr @str.498, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5415,24 +5424,24 @@ while.body.211: ; preds = %while.hdr.210 while.exit.212: ; preds = %while.hdr.210 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) ret { ptr, i64 } %callN if.then.213: ; preds = %while.body.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.214 if.merge.214: ; preds = %if.then.213, %while.body.211 %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.502, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.504, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5472,7 +5481,7 @@ fv.case20: ; preds = %if.merge.214 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5481,7 +5490,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 12 }, { ptr, i64 } { ptr @str.505, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 12 }, { ptr, i64 } { ptr @str.507, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5500,24 +5509,24 @@ while.body.216: ; preds = %while.hdr.215 while.exit.217: ; preds = %while.hdr.215 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) ret { ptr, i64 } %callN if.then.218: ; preds = %while.body.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.219 if.merge.219: ; preds = %if.then.218, %while.body.216 %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.508, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.510, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5537,7 +5546,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 8 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 8 }, { ptr, i64 } { ptr @str.513, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5556,24 +5565,24 @@ while.body.221: ; preds = %while.hdr.220 while.exit.222: ; preds = %while.hdr.220 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 1 }) ret { ptr, i64 } %callN if.then.223: ; preds = %while.body.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.224 if.merge.224: ; preds = %if.then.223, %while.body.221 %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.517, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.519, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5625,7 +5634,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 7 }, { ptr, i64 } { ptr @str.520, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 7 }, { ptr, i64 } { ptr @str.522, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5644,24 +5653,24 @@ while.body.226: ; preds = %while.hdr.225 while.exit.227: ; preds = %while.hdr.225 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 1 }) ret { ptr, i64 } %callN if.then.228: ; preds = %while.body.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.229 if.merge.229: ; preds = %if.then.228, %while.body.226 %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.526, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.528, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5713,7 +5722,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.528, i64 9 }, { ptr, i64 } { ptr @str.529, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 9 }, { ptr, i64 } { ptr @str.531, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5732,24 +5741,24 @@ while.body.231: ; preds = %while.hdr.230 while.exit.232: ; preds = %while.hdr.230 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) ret { ptr, i64 } %callN if.then.233: ; preds = %while.body.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.234 if.merge.234: ; preds = %if.then.233, %while.body.231 %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.534, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.536, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5792,7 +5801,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.536, i64 4 }, { ptr, i64 } { ptr @str.537, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 4 }, { ptr, i64 } { ptr @str.539, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5811,24 +5820,24 @@ while.body.236: ; preds = %while.hdr.235 while.exit.237: ; preds = %while.hdr.235 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) ret { ptr, i64 } %callN if.then.238: ; preds = %while.body.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.239 if.merge.239: ; preds = %if.then.238, %while.body.236 %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.542, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.544, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5874,7 +5883,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.544, i64 6 }, { ptr, i64 } { ptr @str.545, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5893,24 +5902,24 @@ while.body.241: ; preds = %while.hdr.240 while.exit.242: ; preds = %while.hdr.240 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) ret { ptr, i64 } %callN if.then.243: ; preds = %while.body.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.244 if.merge.244: ; preds = %if.then.243, %while.body.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.555, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.557, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.558, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5992,7 +6001,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.557, i64 6 }, { ptr, i64 } { ptr @str.558, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, i64 6 }, { ptr, i64 } { ptr @str.560, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6011,24 +6020,24 @@ while.body.246: ; preds = %while.hdr.245 while.exit.247: ; preds = %while.hdr.245 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.559, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) ret { ptr, i64 } %callN if.then.248: ; preds = %while.body.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.249 if.merge.249: ; preds = %if.then.248, %while.body.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.565, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.567, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6083,7 +6092,7 @@ define internal { ptr, i64 } @struct_to_string__Greeter(ptr %0, { ptr, ptr } %1) entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 7 }, { ptr, i64 } { ptr @str.568, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 7 }, { ptr, i64 } { ptr @str.570, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6102,24 +6111,24 @@ while.body.251: ; preds = %while.hdr.250 while.exit.252: ; preds = %while.hdr.250 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) ret { ptr, i64 } %callN if.then.253: ; preds = %while.body.251 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.254 if.merge.254: ; preds = %if.then.253, %while.body.251 %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.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.576, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6160,7 +6169,7 @@ define internal { ptr, i64 } @struct_to_string____Greeter__Vtable(ptr %0, { ptr entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, i64 17 }, { ptr, i64 } { ptr @str.576, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 17 }, { ptr, i64 } { ptr @str.578, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6179,24 +6188,24 @@ while.body.256: ; preds = %while.hdr.255 while.exit.257: ; preds = %while.hdr.255 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) ret { ptr, i64 } %callN if.then.258: ; preds = %while.body.256 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.259 if.merge.259: ; preds = %if.then.258, %while.body.256 %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.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.582, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6230,7 +6239,7 @@ define internal { ptr, i64 } @struct_to_string__Dog(ptr %0, { i64 } %1) #0 { entry: %alloca = alloca { i64 }, align 8 store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, i64 3 }, { ptr, i64 } { ptr @str.583, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 3 }, { ptr, i64 } { ptr @str.585, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6249,24 +6258,24 @@ while.body.261: ; preds = %while.hdr.260 while.exit.262: ; preds = %while.hdr.260 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.586, i64 1 }) ret { ptr, i64 } %callN if.then.263: ; preds = %while.body.261 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 if.merge.264: ; preds = %if.then.263, %while.body.261 %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.587, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, 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 @@ -6299,7 +6308,7 @@ define internal { ptr, i64 } @struct_to_string__Cat(ptr %0, { i64 } %1) #0 { entry: %alloca = alloca { i64 }, align 8 store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.589, i64 3 }, { ptr, i64 } { ptr @str.590, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.591, i64 3 }, { ptr, i64 } { ptr @str.592, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6318,24 +6327,24 @@ while.body.266: ; preds = %while.hdr.265 while.exit.267: ; preds = %while.hdr.265 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) ret { ptr, i64 } %callN if.then.268: ; preds = %while.body.266 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.269 if.merge.269: ; preds = %if.then.268, %while.body.266 %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.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, 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 @@ -6372,9 +6381,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.601, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.596, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, 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 @@ -6393,8 +6402,8 @@ entry: if.then.277: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.602, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.278 @@ -6413,9 +6422,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.608, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.610, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, 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 @@ -6434,8 +6443,8 @@ entry: if.then.279: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.609, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.611, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6465,9 +6474,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.618, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.620, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.611, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.613, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6484,8 +6493,8 @@ entry: if.then.281: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.619, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.282 @@ -6563,9 +6572,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.629, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.631, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.623, 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 @@ -6584,8 +6593,8 @@ entry: if.then.283: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.284 @@ -6604,9 +6613,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.638, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.640, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, 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 @@ -6625,8 +6634,8 @@ entry: if.then.285: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6643,7 +6652,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.641, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.643, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6660,12 +6669,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.644, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.643, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.645, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6694,7 +6703,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.644, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.646, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6711,12 +6720,12 @@ while.body.302: ; preds = %while.hdr.301 while.exit.303: ; preds = %while.hdr.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.645, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.647, i64 1 }) ret { ptr, i64 } %call if.then.304: ; preds = %while.body.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.646, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.648, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 @@ -6746,7 +6755,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.647, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.649, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.306 @@ -6763,12 +6772,12 @@ while.body.307: ; preds = %while.hdr.306 while.exit.308: ; preds = %while.hdr.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.648, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.650, i64 1 }) ret { ptr, i64 } %call if.then.309: ; preds = %while.body.307 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.649, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.651, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.310 @@ -6796,7 +6805,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.650, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.652, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.311 @@ -6813,12 +6822,12 @@ while.body.312: ; preds = %while.hdr.311 while.exit.313: ; preds = %while.hdr.311 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.651, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.653, i64 1 }) ret { ptr, i64 } %call if.then.314: ; preds = %while.body.312 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.652, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.654, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.315 @@ -6847,7 +6856,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.653, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.655, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.316 @@ -6864,12 +6873,12 @@ while.body.317: ; preds = %while.hdr.316 while.exit.318: ; preds = %while.hdr.316 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.654, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.656, i64 1 }) ret { ptr, i64 } %call if.then.319: ; preds = %while.body.317 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.655, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.657, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.320 @@ -6898,7 +6907,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [2 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.656, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.658, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.321 @@ -6915,12 +6924,12 @@ while.body.322: ; preds = %while.hdr.321 while.exit.323: ; preds = %while.hdr.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.657, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 1 }) ret { ptr, i64 } %call if.then.324: ; preds = %while.body.322 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.325 @@ -6951,7 +6960,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.659, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.661, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.326 @@ -6968,12 +6977,12 @@ while.body.327: ; preds = %while.hdr.326 while.exit.328: ; preds = %while.hdr.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 1 }) ret { ptr, i64 } %call if.then.329: ; preds = %while.body.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.330 @@ -7003,7 +7012,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.662, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.664, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.339 @@ -7022,12 +7031,12 @@ while.body.340: ; preds = %while.hdr.339 while.exit.341: ; preds = %while.hdr.339 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 1 }) ret { ptr, i64 } %call if.then.342: ; preds = %while.body.340 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.343 @@ -7056,7 +7065,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.665, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.667, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.344 @@ -7075,12 +7084,12 @@ while.body.345: ; preds = %while.hdr.344 while.exit.346: ; preds = %while.hdr.344 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 1 }) ret { ptr, i64 } %call if.then.347: ; preds = %while.body.345 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.348 @@ -7109,7 +7118,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.668, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.670, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.349 @@ -7128,12 +7137,12 @@ while.body.350: ; preds = %while.hdr.349 while.exit.351: ; preds = %while.hdr.349 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 1 }) ret { ptr, i64 } %call if.then.352: ; preds = %while.body.350 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.353 @@ -7163,7 +7172,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.671, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.673, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.354 @@ -7182,12 +7191,12 @@ while.body.355: ; preds = %while.hdr.354 while.exit.356: ; preds = %while.hdr.354 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 1 }) ret { ptr, i64 } %call if.then.357: ; preds = %while.body.355 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.358 @@ -7217,7 +7226,7 @@ entry: %ba.tmp = alloca { ptr, ptr }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.674, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.676, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.359 @@ -7236,12 +7245,12 @@ while.body.360: ; preds = %while.hdr.359 while.exit.361: ; preds = %while.hdr.359 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 1 }) ret { ptr, i64 } %call if.then.362: ; preds = %while.body.360 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.363 @@ -7271,7 +7280,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.677, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.679, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.364 @@ -7290,12 +7299,12 @@ while.body.365: ; preds = %while.hdr.364 while.exit.366: ; preds = %while.hdr.364 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 1 }) ret { ptr, i64 } %call if.then.367: ; preds = %while.body.365 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.368 @@ -7337,12 +7346,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 5 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -7365,12 +7374,12 @@ if.then.422: ; preds = %entry if.else.423: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 11 }, { ptr, i64 } %callN) br label %if.merge.424 if.merge.424: ; preds = %if.else.423, %if.then.422 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] ret { ptr, i64 } %bp } @@ -7393,12 +7402,12 @@ if.then.425: ; preds = %entry if.else.426: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 4 }, { ptr, i64 } %callN) br label %if.merge.427 if.merge.427: ; preds = %if.else.426, %if.then.425 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -7421,12 +7430,12 @@ if.then.428: ; preds = %entry if.else.429: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 11 }, { ptr, i64 } %callN) br label %if.merge.430 if.merge.430: ; preds = %if.else.429, %if.then.428 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7449,12 +7458,12 @@ if.then.431: ; preds = %entry if.else.432: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 6 }, { ptr, i64 } %callN) br label %if.merge.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7476,12 +7485,12 @@ if.then.434: ; preds = %entry if.else.435: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 5 }, { ptr, i64 } %callN) br label %if.merge.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7504,12 +7513,12 @@ if.then.437: ; preds = %entry if.else.438: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 9 }, { ptr, i64 } %callN) br label %if.merge.439 if.merge.439: ; preds = %if.else.438, %if.then.437 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7532,12 +7541,12 @@ if.then.440: ; preds = %entry if.else.441: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 18 }, { ptr, i64 } %callN) br label %if.merge.442 if.merge.442: ; preds = %if.else.441, %if.then.440 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7560,12 +7569,12 @@ if.then.443: ; preds = %entry if.else.444: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 5 }, { ptr, i64 } %callN) br label %if.merge.445 if.merge.445: ; preds = %if.else.444, %if.then.443 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7588,12 +7597,12 @@ if.then.446: ; preds = %entry if.else.447: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %callN) br label %if.merge.448 if.merge.448: ; preds = %if.else.447, %if.then.446 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7616,12 +7625,12 @@ if.then.449: ; preds = %entry if.else.450: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 4 }, { ptr, i64 } %callN) br label %if.merge.451 if.merge.451: ; preds = %if.else.450, %if.then.449 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7644,12 +7653,12 @@ if.then.452: ; preds = %entry if.else.453: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 9 }, { ptr, i64 } %callN) br label %if.merge.454 if.merge.454: ; preds = %if.else.453, %if.then.452 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7672,12 +7681,12 @@ if.then.455: ; preds = %entry if.else.456: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 4 }, { ptr, i64 } %callN) br label %if.merge.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7699,12 +7708,12 @@ if.then.458: ; preds = %entry if.else.459: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 8 }, { ptr, i64 } %callN) br label %if.merge.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7727,12 +7736,12 @@ if.then.461: ; preds = %entry if.else.462: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 6 }, { ptr, i64 } %callN) br label %if.merge.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7754,12 +7763,12 @@ if.then.464: ; preds = %entry if.else.465: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 9 }, { ptr, i64 } %callN) br label %if.merge.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7782,12 +7791,12 @@ if.then.467: ; preds = %entry if.else.468: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 7 }, { ptr, i64 } %callN) br label %if.merge.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7810,12 +7819,12 @@ if.then.470: ; preds = %entry if.else.471: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 5 }, { ptr, i64 } %callN) br label %if.merge.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7838,12 +7847,12 @@ if.then.473: ; preds = %entry if.else.474: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 7 }, { ptr, i64 } %callN) br label %if.merge.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7866,12 +7875,12 @@ if.then.476: ; preds = %entry if.else.477: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 4 }, { ptr, i64 } %callN) br label %if.merge.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7894,12 +7903,12 @@ if.then.479: ; preds = %entry if.else.480: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 7 }, { ptr, i64 } %callN) br label %if.merge.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7922,12 +7931,12 @@ if.then.482: ; preds = %entry if.else.483: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 5 }, { ptr, i64 } %callN) br label %if.merge.484 if.merge.484: ; preds = %if.else.483, %if.then.482 - %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -7950,12 +7959,12 @@ if.then.485: ; preds = %entry if.else.486: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 7 }, { ptr, i64 } %callN) br label %if.merge.487 if.merge.487: ; preds = %if.else.486, %if.then.485 - %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -7978,12 +7987,12 @@ if.then.488: ; preds = %entry if.else.489: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 4 }, { ptr, i64 } %callN) br label %if.merge.490 if.merge.490: ; preds = %if.else.489, %if.then.488 - %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -8006,12 +8015,12 @@ if.then.491: ; preds = %entry if.else.492: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 4 }, { ptr, i64 } %callN) br label %if.merge.493 if.merge.493: ; preds = %if.else.492, %if.then.491 - %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -8034,12 +8043,12 @@ if.then.494: ; preds = %entry if.else.495: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 12 }, { ptr, i64 } %callN) br label %if.merge.496 if.merge.496: ; preds = %if.else.495, %if.then.494 - %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -8062,12 +8071,12 @@ if.then.497: ; preds = %entry if.else.498: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 6 }, { ptr, i64 } %callN) br label %if.merge.499 if.merge.499: ; preds = %if.else.498, %if.then.497 - %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -8090,12 +8099,12 @@ if.then.500: ; preds = %entry if.else.501: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 4 }, { ptr, i64 } %callN) br label %if.merge.502 if.merge.502: ; preds = %if.else.501, %if.then.500 - %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -8118,12 +8127,12 @@ if.then.503: ; preds = %entry if.else.504: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 7 }, { ptr, i64 } %callN) br label %if.merge.505 if.merge.505: ; preds = %if.else.504, %if.then.503 - %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -8146,12 +8155,12 @@ if.then.506: ; preds = %entry if.else.507: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 6 }, { ptr, i64 } %callN) br label %if.merge.508 if.merge.508: ; preds = %if.else.507, %if.then.506 - %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -8174,12 +8183,12 @@ if.then.509: ; preds = %entry if.else.510: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 5 }, { ptr, i64 } %callN) br label %if.merge.511 if.merge.511: ; preds = %if.else.510, %if.then.509 - %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -8202,12 +8211,12 @@ if.then.512: ; preds = %entry if.else.513: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 5 }, { ptr, i64 } %callN) br label %if.merge.514 if.merge.514: ; preds = %if.else.513, %if.then.512 - %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -8230,12 +8239,12 @@ if.then.515: ; preds = %entry if.else.516: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 7 }, { ptr, i64 } %callN) br label %if.merge.517 if.merge.517: ; preds = %if.else.516, %if.then.515 - %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -8258,12 +8267,12 @@ if.then.518: ; preds = %entry if.else.519: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 7 }, { ptr, i64 } %callN) br label %if.merge.520 if.merge.520: ; preds = %if.else.519, %if.then.518 - %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -8286,12 +8295,12 @@ if.then.521: ; preds = %entry if.else.522: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 5 }, { ptr, i64 } %callN) br label %if.merge.523 if.merge.523: ; preds = %if.else.522, %if.then.521 - %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -8307,7 +8316,7 @@ entry: br i1 %lnot, label %if.then.530, label %if.merge.531 if.then.530: ; preds = %entry - ret { ptr, i64 } { ptr @str.785, i64 4 } + ret { ptr, i64 } { ptr @str.787, i64 4 } if.merge.531: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8331,7 +8340,7 @@ entry: br i1 %lnot, label %if.then.532, label %if.merge.533 if.then.532: ; preds = %entry - ret { ptr, i64 } { ptr @str.786, i64 4 } + ret { ptr, i64 } { ptr @str.788, i64 4 } if.merge.533: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8355,7 +8364,7 @@ entry: br i1 %lnot, label %if.then.534, label %if.merge.535 if.then.534: ; preds = %entry - ret { ptr, i64 } { ptr @str.787, i64 4 } + ret { ptr, i64 } { ptr @str.789, i64 4 } if.merge.535: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8379,7 +8388,7 @@ entry: br i1 %lnot, label %if.then.536, label %if.merge.537 if.then.536: ; preds = %entry - ret { ptr, i64 } { ptr @str.788, i64 4 } + ret { ptr, i64 } { ptr @str.790, i64 4 } if.merge.537: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0838-memory-helpers.exit b/examples/expected/0838-memory-helpers.exit new file mode 100644 index 0000000..573541a --- /dev/null +++ b/examples/expected/0838-memory-helpers.exit @@ -0,0 +1 @@ +0 diff --git a/examples/expected/0838-memory-helpers.stderr b/examples/expected/0838-memory-helpers.stderr new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/examples/expected/0838-memory-helpers.stderr @@ -0,0 +1 @@ + diff --git a/examples/expected/0838-memory-helpers.stdout b/examples/expected/0838-memory-helpers.stdout new file mode 100644 index 0000000..be7e278 --- /dev/null +++ b/examples/expected/0838-memory-helpers.stdout @@ -0,0 +1,8 @@ +create: 7 42 +pipe-create: 1 +alloc: 10 40 len=4 +clone: 10 (orig 99) +resize: 20 60 len=6 +shrink: 99 20 len=2 +realloc: 1234 +TrackingAllocator: allocs=8 deallocs=8 outstanding=0 total_alloc_bytes=184 diff --git a/examples/expected/0903-optionals-optional-roundtrip.ir b/examples/expected/0903-optionals-optional-roundtrip.ir index b951de1..5886a7c 100644 --- a/examples/expected/0903-optionals-optional-roundtrip.ir +++ b/examples/expected/0903-optionals-optional-roundtrip.ir @@ -2,700 +2,700 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @__Sizable__Widget__vtable = internal constant { ptr } { ptr @__thunk_Widget_Sizable_size } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [177 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [5 x i8] c"?f32\00" -@tn.str.237 = private constant [13 x i8] c"ProposedSize\00" -@tn.str.238 = private constant [8 x i8] c"Sizable\00" -@tn.str.239 = private constant [18 x i8] c"__Sizable__Vtable\00" -@tn.str.240 = private constant [7 x i8] c"Widget\00" -@tn.str.241 = private constant [8 x i8] c"*Widget\00" -@tn.str.242 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.243 = private constant [7 x i8] c"**void\00" -@tn.str.244 = private constant [8 x i8] c"*string\00" -@tn.str.245 = private constant [6 x i8] c"[]Any\00" -@tn.str.246 = private constant [5 x i8] c"*Any\00" -@tn.str.247 = private constant [7 x i8] c"*[]Any\00" -@tn.str.248 = private constant [6 x i8] c"*bool\00" -@tn.str.249 = private constant [14 x i8] c"*ProposedSize\00" -@tn.str.250 = private constant [5 x i8] c"*f32\00" -@tn.str.251 = private constant [5 x i8] c"*f64\00" -@tn.str.252 = private constant [7 x i8] c"[1]Any\00" -@tn.str.253 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.254 = private constant [9 x i8] c"*Sizable\00" -@tn.str.255 = private constant [9 x i8] c"**Widget\00" -@tn.str.256 = private constant [19 x i8] c"*__Sizable__Vtable\00" -@tn.str.257 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.258 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.259 = private constant [11 x i8] c"*Allocator\00" -@tn.str.260 = private constant [9 x i8] c"*Context\00" -@tn.str.261 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.262 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.263 = private constant [8 x i8] c"*Member\00" -@tn.str.264 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.265 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.266 = private constant [9 x i8] c"*Command\00" -@tn.str.267 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.268 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.269 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.270 = private constant [7 x i8] c"*Value\00" -@tn.str.271 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.272 = private constant [14 x i8] c"*Architecture\00" -@tn.str.273 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.274 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.275 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.276 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.277 = private constant [10 x i8] c"*[]string\00" -@tn.str.278 = private constant [6 x i8] c"*[]u8\00" -@tn.str.279 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.280 = private constant [11 x i8] c"*[]Command\00" -@tn.str.281 = private constant [6 x i8] c"**GPA\00" -@tn.str.282 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.283 = private constant [8 x i8] c"**Arena\00" -@tn.str.284 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.285 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.286 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.287 = private constant [7 x i8] c"**File\00" -@tn.str.288 = private constant [5 x i8] c"**u8\00" -@tn.str.289 = private constant [6 x i8] c"**s32\00" -@tn.str.290 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.291 = private constant [6 x i8] c"**u32\00" -@tn.str.292 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.293 = private constant [8 x i8] c"**Array\00" -@tn.str.294 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.295 = private constant [9 x i8] c"**Object\00" -@tn.str.296 = private constant [7 x i8] c"**Sink\00" -@tn.str.297 = private constant [9 x i8] c"**Parser\00" -@tn.str.298 = private constant [6 x i8] c"**s64\00" -@tn.str.299 = private constant [9 x i8] c"**Parsed\00" -@tn.str.300 = private constant [7 x i8] c"**Diag\00" -@tn.str.301 = private constant [9 x i8] c"**Sha256\00" -@tn.str.302 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.303 = private constant [8 x i8] c"***void\00" -@tn.str.304 = private constant [9 x i8] c"**string\00" -@tn.str.305 = private constant [6 x i8] c"**Any\00" -@tn.str.306 = private constant [8 x i8] c"**[]Any\00" -@tn.str.307 = private constant [7 x i8] c"**bool\00" -@tn.str.308 = private constant [15 x i8] c"**ProposedSize\00" -@tn.str.309 = private constant [6 x i8] c"**f32\00" -@tn.str.310 = private constant [6 x i8] c"**f64\00" -@tn.str.311 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.312 = private constant [10 x i8] c"**Sizable\00" -@tn.str.313 = private constant [10 x i8] c"***Widget\00" -@tn.str.314 = private constant [20 x i8] c"**__Sizable__Vtable\00" -@tn.str.315 = private constant [7 x i8] c"*?File\00" -@tn.str.316 = private constant [9 x i8] c"*?string\00" -@tn.str.317 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.318 = private constant [9 x i8] c"*?[64]u8\00" -@tn.str.319 = private constant [6 x i8] c"*?f32\00" -@__sx_type_names = private constant [177 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 4 }, { ptr, i64 } { ptr @tn.str.237, i64 12 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 17 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 12 }, { ptr, i64 } { ptr @tn.str.243, i64 6 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 13 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 4 }, { ptr, i64 } { ptr @tn.str.252, i64 6 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 8 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 18 }, { ptr, i64 } { ptr @tn.str.257, i64 7 }, { ptr, i64 } { ptr @tn.str.258, i64 16 }, { ptr, i64 } { ptr @tn.str.259, i64 10 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 11 }, { ptr, i64 } { ptr @tn.str.262, i64 14 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 13 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 8 }, { ptr, i64 } { ptr @tn.str.267, i64 10 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 6 }, { ptr, i64 } { ptr @tn.str.271, i64 16 }, { ptr, i64 } { ptr @tn.str.272, i64 13 }, { ptr, i64 } { ptr @tn.str.273, i64 14 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 7 }, { ptr, i64 } { ptr @tn.str.276, i64 8 }, { ptr, i64 } { ptr @tn.str.277, i64 9 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 11 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 12 }, { ptr, i64 } { ptr @tn.str.283, i64 7 }, { ptr, i64 } { ptr @tn.str.284, i64 6 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 19 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 4 }, { ptr, i64 } { ptr @tn.str.289, i64 5 }, { ptr, i64 } { ptr @tn.str.290, i64 10 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 9 }, { ptr, i64 } { ptr @tn.str.293, i64 7 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 6 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 6 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 13 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 5 }, { ptr, i64 } { ptr @tn.str.306, i64 7 }, { ptr, i64 } { ptr @tn.str.307, i64 6 }, { ptr, i64 } { ptr @tn.str.308, i64 14 }, { ptr, i64 } { ptr @tn.str.309, i64 5 }, { ptr, i64 } { ptr @tn.str.310, i64 5 }, { ptr, i64 } { ptr @tn.str.311, i64 8 }, { ptr, i64 } { ptr @tn.str.312, i64 9 }, { ptr, i64 } { ptr @tn.str.313, i64 9 }, { ptr, i64 } { ptr @tn.str.314, i64 19 }, { ptr, i64 } { ptr @tn.str.315, i64 6 }, { ptr, i64 } { ptr @tn.str.316, i64 8 }, { ptr, i64 } { ptr @tn.str.317, i64 15 }, { ptr, i64 } { ptr @tn.str.318, i64 8 }, { ptr, i64 } { ptr @tn.str.319, i64 5 }] -@str.320 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.321 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [5 x i8] c"?f32\00" +@tn.str.239 = private constant [13 x i8] c"ProposedSize\00" +@tn.str.240 = private constant [8 x i8] c"Sizable\00" +@tn.str.241 = private constant [18 x i8] c"__Sizable__Vtable\00" +@tn.str.242 = private constant [7 x i8] c"Widget\00" +@tn.str.243 = private constant [8 x i8] c"*Widget\00" +@tn.str.244 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.245 = private constant [7 x i8] c"**void\00" +@tn.str.246 = private constant [8 x i8] c"*string\00" +@tn.str.247 = private constant [6 x i8] c"[]Any\00" +@tn.str.248 = private constant [5 x i8] c"*Any\00" +@tn.str.249 = private constant [7 x i8] c"*[]Any\00" +@tn.str.250 = private constant [6 x i8] c"*bool\00" +@tn.str.251 = private constant [14 x i8] c"*ProposedSize\00" +@tn.str.252 = private constant [5 x i8] c"*f32\00" +@tn.str.253 = private constant [5 x i8] c"*f64\00" +@tn.str.254 = private constant [7 x i8] c"[1]Any\00" +@tn.str.255 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.256 = private constant [9 x i8] c"*Sizable\00" +@tn.str.257 = private constant [9 x i8] c"**Widget\00" +@tn.str.258 = private constant [19 x i8] c"*__Sizable__Vtable\00" +@tn.str.259 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.260 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.261 = private constant [11 x i8] c"*Allocator\00" +@tn.str.262 = private constant [9 x i8] c"*Context\00" +@tn.str.263 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.264 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.265 = private constant [8 x i8] c"*Member\00" +@tn.str.266 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.267 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.268 = private constant [9 x i8] c"*Command\00" +@tn.str.269 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.270 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.271 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.272 = private constant [7 x i8] c"*Value\00" +@tn.str.273 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.274 = private constant [14 x i8] c"*Architecture\00" +@tn.str.275 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.276 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.277 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.278 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.279 = private constant [10 x i8] c"*[]string\00" +@tn.str.280 = private constant [6 x i8] c"*[]u8\00" +@tn.str.281 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.282 = private constant [11 x i8] c"*[]Command\00" +@tn.str.283 = private constant [6 x i8] c"**GPA\00" +@tn.str.284 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.285 = private constant [8 x i8] c"**Arena\00" +@tn.str.286 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.287 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.288 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.289 = private constant [7 x i8] c"**File\00" +@tn.str.290 = private constant [5 x i8] c"**u8\00" +@tn.str.291 = private constant [6 x i8] c"**s32\00" +@tn.str.292 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.293 = private constant [6 x i8] c"**u32\00" +@tn.str.294 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.295 = private constant [8 x i8] c"**Array\00" +@tn.str.296 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.297 = private constant [9 x i8] c"**Object\00" +@tn.str.298 = private constant [7 x i8] c"**Sink\00" +@tn.str.299 = private constant [9 x i8] c"**Parser\00" +@tn.str.300 = private constant [6 x i8] c"**s64\00" +@tn.str.301 = private constant [9 x i8] c"**Parsed\00" +@tn.str.302 = private constant [7 x i8] c"**Diag\00" +@tn.str.303 = private constant [9 x i8] c"**Sha256\00" +@tn.str.304 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.305 = private constant [8 x i8] c"***void\00" +@tn.str.306 = private constant [9 x i8] c"**string\00" +@tn.str.307 = private constant [6 x i8] c"**Any\00" +@tn.str.308 = private constant [8 x i8] c"**[]Any\00" +@tn.str.309 = private constant [7 x i8] c"**bool\00" +@tn.str.310 = private constant [15 x i8] c"**ProposedSize\00" +@tn.str.311 = private constant [6 x i8] c"**f32\00" +@tn.str.312 = private constant [6 x i8] c"**f64\00" +@tn.str.313 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.314 = private constant [10 x i8] c"**Sizable\00" +@tn.str.315 = private constant [10 x i8] c"***Widget\00" +@tn.str.316 = private constant [20 x i8] c"**__Sizable__Vtable\00" +@tn.str.317 = private constant [7 x i8] c"*?File\00" +@tn.str.318 = private constant [9 x i8] c"*?string\00" +@tn.str.319 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.320 = private constant [9 x i8] c"*?[64]u8\00" +@tn.str.321 = private constant [6 x i8] c"*?f32\00" +@__sx_type_names = private constant [177 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 4 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 17 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 12 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 5 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 13 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 4 }, { ptr, i64 } { ptr @tn.str.254, i64 6 }, { ptr, i64 } { ptr @tn.str.255, i64 7 }, { ptr, i64 } { ptr @tn.str.256, i64 8 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 18 }, { ptr, i64 } { ptr @tn.str.259, i64 7 }, { ptr, i64 } { ptr @tn.str.260, i64 16 }, { ptr, i64 } { ptr @tn.str.261, i64 10 }, { ptr, i64 } { ptr @tn.str.262, i64 8 }, { ptr, i64 } { ptr @tn.str.263, i64 11 }, { ptr, i64 } { ptr @tn.str.264, i64 14 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 13 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 8 }, { ptr, i64 } { ptr @tn.str.269, i64 10 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 9 }, { ptr, i64 } { ptr @tn.str.272, i64 6 }, { ptr, i64 } { ptr @tn.str.273, i64 16 }, { ptr, i64 } { ptr @tn.str.274, i64 13 }, { ptr, i64 } { ptr @tn.str.275, i64 14 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 7 }, { ptr, i64 } { ptr @tn.str.278, i64 8 }, { ptr, i64 } { ptr @tn.str.279, i64 9 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 11 }, { ptr, i64 } { ptr @tn.str.282, i64 10 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 12 }, { ptr, i64 } { ptr @tn.str.285, i64 7 }, { ptr, i64 } { ptr @tn.str.286, i64 6 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 19 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 4 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 10 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 9 }, { ptr, i64 } { ptr @tn.str.295, i64 7 }, { ptr, i64 } { ptr @tn.str.296, i64 10 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 6 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 5 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 13 }, { ptr, i64 } { ptr @tn.str.305, i64 7 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 5 }, { ptr, i64 } { ptr @tn.str.308, i64 7 }, { ptr, i64 } { ptr @tn.str.309, i64 6 }, { ptr, i64 } { ptr @tn.str.310, i64 14 }, { ptr, i64 } { ptr @tn.str.311, i64 5 }, { ptr, i64 } { ptr @tn.str.312, i64 5 }, { ptr, i64 } { ptr @tn.str.313, i64 8 }, { ptr, i64 } { ptr @tn.str.314, i64 9 }, { ptr, i64 } { ptr @tn.str.315, i64 9 }, { ptr, i64 } { ptr @tn.str.316, i64 19 }, { ptr, i64 } { ptr @tn.str.317, i64 6 }, { ptr, i64 } { ptr @tn.str.318, i64 8 }, { ptr, i64 } { ptr @tn.str.319, i64 15 }, { ptr, i64 } { ptr @tn.str.320, i64 8 }, { ptr, i64 } { ptr @tn.str.321, i64 5 }] @str.322 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.323 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.324 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.325 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.326 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.327 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.328 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.329 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.330 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.331 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.332 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.333 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.334 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.335 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.336 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.337 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.338 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.340 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.341 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", align 1 -@str.342 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.326 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.327 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.328 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.329 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.330 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.331 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.332 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.333 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.334 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.335 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.336 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.337 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.338 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.339 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.340 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.342 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.343 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", align 1 -@str.344 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", align 1 -@str.345 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.344 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.345 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", align 1 @str.346 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", align 1 -@str.347 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", align 1 -@str.348 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.347 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.348 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", align 1 @str.349 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", align 1 -@str.350 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", align 1 -@str.351 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.350 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.351 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", align 1 @str.352 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", align 1 -@str.353 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", align 1 -@str.354 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.353 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.354 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", align 1 @str.355 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", align 1 -@str.356 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", align 1 -@str.357 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.356 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.357 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", align 1 @str.358 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", align 1 -@str.359 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", align 1 -@str.360 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.359 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.360 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", align 1 @str.361 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", align 1 -@str.362 = private unnamed_addr constant [9 x i8] c"r2 = {}\0A\00", align 1 -@str.363 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.362 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.363 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", align 1 @str.364 = private unnamed_addr constant [9 x i8] c"r2 = {}\0A\00", align 1 -@str.365 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", align 1 -@str.366 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.365 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.366 = private unnamed_addr constant [9 x i8] c"r2 = {}\0A\00", align 1 @str.367 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", align 1 -@str.368 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1 -@str.369 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.368 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.369 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", align 1 @str.370 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1 -@str.371 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.372 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.374 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.371 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.372 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1 +@str.373 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.374 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.375 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.376 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.375 = private constant [5 x i8] c"line\00" -@fld.str.376 = private constant [4 x i8] c"col\00" -@fld.str.377 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.375, i64 4 }, { ptr, i64 } { ptr @fld.str.376, i64 3 }, { ptr, i64 } { ptr @fld.str.377, i64 4 }] -@str.378 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.379 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.380 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.381 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.382 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.383 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.385 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.389 = private constant [12 x i8] c"alloc_count\00" -@field_names.390 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 11 }] -@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.392 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.396 = private constant [5 x i8] c"next\00" -@fld.str.397 = private constant [4 x i8] c"cap\00" -@field_names.398 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 4 }, { ptr, i64 } { ptr @fld.str.397, i64 3 }] -@str.399 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.400 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.401 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.402 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.403 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.404 = private constant [4 x i8] c"ctx\00" -@fld.str.405 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.406 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.407 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.404, i64 3 }, { ptr, i64 } { ptr @fld.str.405, i64 11 }, { ptr, i64 } { ptr @fld.str.406, i64 13 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [6 x i8] c"first\00" -@fld.str.414 = private constant [10 x i8] c"end_index\00" -@fld.str.415 = private constant [7 x i8] c"parent\00" -@field_names.416 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 5 }, { ptr, i64 } { ptr @fld.str.414, i64 9 }, { ptr, i64 } { ptr @fld.str.415, i64 6 }] -@str.417 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.418 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.420 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.421 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.422 = private constant [4 x i8] c"buf\00" -@fld.str.423 = private constant [4 x i8] c"len\00" -@fld.str.424 = private constant [4 x i8] c"pos\00" -@field_names.425 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.422, i64 3 }, { ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 3 }] -@str.426 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.427 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.428 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.430 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.431 = private constant [7 x i8] c"parent\00" -@fld.str.432 = private constant [12 x i8] c"alloc_count\00" -@fld.str.433 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.434 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.435 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.431, i64 6 }, { ptr, i64 } { ptr @fld.str.432, i64 11 }, { ptr, i64 } { ptr @fld.str.433, i64 13 }, { ptr, i64 } { ptr @fld.str.434, i64 17 }] -@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.437 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.441 = private constant [10 x i8] c"allocator\00" -@fld.str.442 = private constant [5 x i8] c"data\00" -@field_names.443 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 9 }, { ptr, i64 } { ptr @fld.str.442, i64 4 }] -@str.444 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.445 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.446 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.447 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.448 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.449 = private constant [3 x i8] c"fd\00" -@field_names.450 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.449, i64 2 }] -@str.451 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.452 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.453 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.454 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.455 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.456 = private constant [5 x i8] c"file\00" -@fld.str.457 = private constant [5 x i8] c"line\00" -@fld.str.458 = private constant [4 x i8] c"col\00" -@fld.str.459 = private constant [5 x i8] c"func\00" -@fld.str.460 = private constant [10 x i8] c"line_text\00" -@field_names.461 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.456, i64 4 }, { ptr, i64 } { ptr @fld.str.457, i64 4 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }, { ptr, i64 } { ptr @fld.str.459, i64 4 }, { ptr, i64 } { ptr @fld.str.460, i64 9 }] -@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.463 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.467 = private constant [10 x i8] c"exit_code\00" -@fld.str.468 = private constant [7 x i8] c"stdout\00" -@field_names.469 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 9 }, { ptr, i64 } { ptr @fld.str.468, i64 6 }] -@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.471 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.475 = private constant [8 x i8] c"sin_len\00" -@fld.str.476 = private constant [11 x i8] c"sin_family\00" -@fld.str.477 = private constant [9 x i8] c"sin_port\00" -@fld.str.478 = private constant [9 x i8] c"sin_addr\00" -@fld.str.479 = private constant [9 x i8] c"sin_zero\00" -@field_names.480 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 7 }, { ptr, i64 } { ptr @fld.str.476, i64 10 }, { ptr, i64 } { ptr @fld.str.477, i64 8 }, { ptr, i64 } { ptr @fld.str.478, i64 8 }, { ptr, i64 } { ptr @fld.str.479, i64 8 }] -@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.482 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.486 = private constant [6 x i8] c"items\00" -@fld.str.487 = private constant [4 x i8] c"len\00" -@fld.str.488 = private constant [4 x i8] c"cap\00" -@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 5 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 3 }] -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.495 = private constant [6 x i8] c"items\00" -@fld.str.496 = private constant [4 x i8] c"len\00" -@fld.str.497 = private constant [4 x i8] c"cap\00" -@field_names.498 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.495, i64 5 }, { ptr, i64 } { ptr @fld.str.496, i64 3 }, { ptr, i64 } { ptr @fld.str.497, i64 3 }] -@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.500 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.502 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.503 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.504 = private constant [4 x i8] c"key\00" -@fld.str.505 = private constant [4 x i8] c"val\00" -@field_names.506 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.504, i64 3 }, { ptr, i64 } { ptr @fld.str.505, i64 3 }] -@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.508 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.512 = private constant [4 x i8] c"dst\00" -@fld.str.513 = private constant [4 x i8] c"pos\00" -@fld.str.514 = private constant [5 x i8] c"file\00" -@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 3 }, { ptr, i64 } { ptr @fld.str.513, i64 3 }, { ptr, i64 } { ptr @fld.str.514, i64 4 }] -@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.517 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.521 = private constant [4 x i8] c"src\00" -@fld.str.522 = private constant [4 x i8] c"pos\00" -@fld.str.523 = private constant [6 x i8] c"alloc\00" -@field_names.524 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 3 }, { ptr, i64 } { ptr @fld.str.523, i64 5 }] -@str.525 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.526 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.527 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.528 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.529 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.530 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.531 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.532 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.533 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.534 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.535 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.536 = private constant [5 x i8] c"name\00" -@fld.str.537 = private constant [12 x i8] c"takes_value\00" -@fld.str.538 = private constant [9 x i8] c"required\00" -@field_names.539 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.536, i64 4 }, { ptr, i64 } { ptr @fld.str.537, i64 11 }, { ptr, i64 } { ptr @fld.str.538, i64 8 }] -@str.540 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.541 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.542 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.543 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.544 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.545 = private constant [6 x i8] c"group\00" -@fld.str.546 = private constant [8 x i8] c"command\00" -@fld.str.547 = private constant [6 x i8] c"flags\00" -@field_names.548 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.545, i64 5 }, { ptr, i64 } { ptr @fld.str.546, i64 7 }, { ptr, i64 } { ptr @fld.str.547, i64 5 }] -@str.549 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.550 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.551 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.553 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.554 = private constant [4 x i8] c"set\00" -@fld.str.555 = private constant [6 x i8] c"value\00" -@field_names.556 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.554, i64 3 }, { ptr, i64 } { ptr @fld.str.555, i64 5 }] -@str.557 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.558 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.559 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.561 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.562 = private constant [6 x i8] c"index\00" -@fld.str.563 = private constant [6 x i8] c"token\00" -@field_names.564 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 5 }, { ptr, i64 } { ptr @fld.str.563, i64 5 }] -@str.565 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.566 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.567 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.569 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.570 = private constant [6 x i8] c"group\00" -@fld.str.571 = private constant [8 x i8] c"command\00" -@fld.str.572 = private constant [10 x i8] c"cmd_index\00" -@fld.str.573 = private constant [5 x i8] c"json\00" -@fld.str.574 = private constant [5 x i8] c"rest\00" -@fld.str.575 = private constant [5 x i8] c"spec\00" -@fld.str.576 = private constant [7 x i8] c"values\00" -@field_names.577 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 7 }, { ptr, i64 } { ptr @fld.str.572, i64 9 }, { ptr, i64 } { ptr @fld.str.573, i64 4 }, { ptr, i64 } { ptr @fld.str.574, i64 4 }, { ptr, i64 } { ptr @fld.str.575, i64 4 }, { ptr, i64 } { ptr @fld.str.576, i64 6 }] -@str.578 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.579 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.580 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.581 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.582 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.583 = private constant [2 x i8] c"h\00" -@fld.str.584 = private constant [4 x i8] c"buf\00" -@fld.str.585 = private constant [8 x i8] c"buf_len\00" -@fld.str.586 = private constant [10 x i8] c"total_len\00" -@field_names.587 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 1 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 9 }] -@str.588 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.589 = private unnamed_addr constant [13 x i8] c"ProposedSize\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.592 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.593 = private constant [6 x i8] c"width\00" -@fld.str.594 = private constant [7 x i8] c"height\00" -@field_names.595 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 5 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }] -@str.596 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.597 = private unnamed_addr constant [8 x i8] c"Sizable\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.600 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.601 = private constant [4 x i8] c"ctx\00" -@fld.str.602 = private constant [9 x i8] c"__vtable\00" -@field_names.603 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.601, i64 3 }, { ptr, i64 } { ptr @fld.str.602, i64 8 }] -@str.604 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.605 = private unnamed_addr constant [18 x i8] c"__Sizable__Vtable\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.609 = private constant [5 x i8] c"size\00" -@field_names.610 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.609, i64 4 }] -@str.611 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.612 = private unnamed_addr constant [7 x i8] c"Widget\00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.616 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.617 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.619 = private constant [5 x i8] c"read\00" -@fld.str.620 = private constant [6 x i8] c"write\00" -@fld.str.621 = private constant [7 x i8] c"append\00" -@fld.str.622 = private constant [11 x i8] c"read_write\00" -@field_names.623 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.619, i64 4 }, { ptr, i64 } { ptr @fld.str.620, i64 5 }, { ptr, i64 } { ptr @fld.str.621, i64 6 }, { ptr, i64 } { ptr @fld.str.622, i64 10 }] -@str.624 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.627 = private constant [4 x i8] c"set\00" -@fld.str.628 = private constant [8 x i8] c"current\00" -@fld.str.629 = private constant [4 x i8] c"end\00" -@field_names.630 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.627, i64 3 }, { ptr, i64 } { ptr @fld.str.628, i64 7 }, { ptr, i64 } { ptr @fld.str.629, i64 3 }] -@str.631 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.633 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.634 = private constant [6 x i8] c"null_\00" -@fld.str.635 = private constant [6 x i8] c"bool_\00" -@fld.str.636 = private constant [5 x i8] c"int_\00" -@fld.str.637 = private constant [4 x i8] c"str\00" -@fld.str.638 = private constant [6 x i8] c"array\00" -@fld.str.639 = private constant [7 x i8] c"object\00" -@field_names.640 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.634, i64 5 }, { ptr, i64 } { ptr @fld.str.635, i64 5 }, { ptr, i64 } { ptr @fld.str.636, i64 4 }, { ptr, i64 } { ptr @fld.str.637, i64 3 }, { ptr, i64 } { ptr @fld.str.638, i64 5 }, { ptr, i64 } { ptr @fld.str.639, i64 6 }] -@str.641 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.642 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.643 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.644 = private constant [6 x i8] c"macos\00" -@fld.str.645 = private constant [6 x i8] c"linux\00" -@fld.str.646 = private constant [8 x i8] c"windows\00" -@fld.str.647 = private constant [5 x i8] c"wasm\00" -@fld.str.648 = private constant [4 x i8] c"ios\00" -@fld.str.649 = private constant [8 x i8] c"android\00" -@fld.str.650 = private constant [8 x i8] c"unknown\00" -@field_names.651 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.644, i64 5 }, { ptr, i64 } { ptr @fld.str.645, i64 5 }, { ptr, i64 } { ptr @fld.str.646, i64 7 }, { ptr, i64 } { ptr @fld.str.647, i64 4 }, { ptr, i64 } { ptr @fld.str.648, i64 3 }, { ptr, i64 } { ptr @fld.str.649, i64 7 }, { ptr, i64 } { ptr @fld.str.650, i64 7 }] -@str.652 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.653 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.654 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.655 = private constant [8 x i8] c"aarch64\00" -@fld.str.656 = private constant [7 x i8] c"x86_64\00" -@fld.str.657 = private constant [7 x i8] c"wasm32\00" -@fld.str.658 = private constant [7 x i8] c"wasm64\00" -@fld.str.659 = private constant [8 x i8] c"unknown\00" -@field_names.660 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.655, i64 7 }, { ptr, i64 } { ptr @fld.str.656, i64 6 }, { ptr, i64 } { ptr @fld.str.657, i64 6 }, { ptr, i64 } { ptr @fld.str.658, i64 6 }, { ptr, i64 } { ptr @fld.str.659, i64 7 }] -@str.661 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.662 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.663 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.664 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.665 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.667 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.668 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.669 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.670 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.671 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.672 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.673 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.674 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.676 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.677 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.678 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.679 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.680 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.681 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.682 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.683 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.684 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.685 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.686 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.687 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.688 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.690 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.691 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.693 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.694 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.695 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.697 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.700 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.706 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.709 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.736 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.737 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.739 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.740 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.742 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.743 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.745 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.746 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.748 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.749 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.750 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.751 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.752 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.753 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.754 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.755 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.756 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.757 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.758 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.759 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.760 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.761 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.762 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.763 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.764 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.765 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.766 = private unnamed_addr constant [8 x i8] c"*Widget\00", align 1 -@str.767 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.768 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.769 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.770 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.771 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.772 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.773 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.774 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.775 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.776 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.777 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.778 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.779 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.780 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.781 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.782 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.783 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.784 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.785 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.787 = private unnamed_addr constant [14 x i8] c"*ProposedSize\00", align 1 -@str.788 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.790 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 -@str.791 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.792 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.793 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 -@str.794 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.795 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.796 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.797 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.798 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.799 = private unnamed_addr constant [9 x i8] c"*Sizable\00", align 1 -@str.800 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.801 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.802 = private unnamed_addr constant [9 x i8] c"**Widget\00", align 1 -@str.803 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.804 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.805 = private unnamed_addr constant [19 x i8] c"*__Sizable__Vtable\00", align 1 -@str.806 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.807 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.808 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.377 = private constant [5 x i8] c"line\00" +@fld.str.378 = private constant [4 x i8] c"col\00" +@fld.str.379 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.377, i64 4 }, { ptr, i64 } { ptr @fld.str.378, i64 3 }, { ptr, i64 } { ptr @fld.str.379, i64 4 }] +@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.381 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.385 = private constant [4 x i8] c"ctx\00" +@fld.str.386 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.387 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.388 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 3 }, { ptr, i64 } { ptr @fld.str.386, i64 11 }, { ptr, i64 } { ptr @fld.str.387, i64 13 }] +@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.390 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.394 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.395 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.396 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.397 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.398 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.399 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.400 = private constant [12 x i8] c"alloc_count\00" +@field_names.401 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.400, i64 11 }] +@str.402 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.403 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.404 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.405 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.406 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.407 = private constant [5 x i8] c"next\00" +@fld.str.408 = private constant [4 x i8] c"cap\00" +@field_names.409 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.407, i64 4 }, { ptr, i64 } { ptr @fld.str.408, i64 3 }] +@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.411 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.415 = private constant [6 x i8] c"first\00" +@fld.str.416 = private constant [10 x i8] c"end_index\00" +@fld.str.417 = private constant [7 x i8] c"parent\00" +@field_names.418 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 5 }, { ptr, i64 } { ptr @fld.str.416, i64 9 }, { ptr, i64 } { ptr @fld.str.417, i64 6 }] +@str.419 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.420 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.422 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.423 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.424 = private constant [4 x i8] c"buf\00" +@fld.str.425 = private constant [4 x i8] c"len\00" +@fld.str.426 = private constant [4 x i8] c"pos\00" +@field_names.427 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.424, i64 3 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }, { ptr, i64 } { ptr @fld.str.426, i64 3 }] +@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.429 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.430 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.432 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.433 = private constant [7 x i8] c"parent\00" +@fld.str.434 = private constant [12 x i8] c"alloc_count\00" +@fld.str.435 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.436 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.437 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 6 }, { ptr, i64 } { ptr @fld.str.434, i64 11 }, { ptr, i64 } { ptr @fld.str.435, i64 13 }, { ptr, i64 } { ptr @fld.str.436, i64 17 }] +@str.438 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.439 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.441 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.442 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.443 = private constant [10 x i8] c"allocator\00" +@fld.str.444 = private constant [5 x i8] c"data\00" +@field_names.445 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.443, i64 9 }, { ptr, i64 } { ptr @fld.str.444, i64 4 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.448 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.449 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.450 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.451 = private constant [3 x i8] c"fd\00" +@field_names.452 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 2 }] +@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.454 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.458 = private constant [5 x i8] c"file\00" +@fld.str.459 = private constant [5 x i8] c"line\00" +@fld.str.460 = private constant [4 x i8] c"col\00" +@fld.str.461 = private constant [5 x i8] c"func\00" +@fld.str.462 = private constant [10 x i8] c"line_text\00" +@field_names.463 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 4 }, { ptr, i64 } { ptr @fld.str.459, i64 4 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }, { ptr, i64 } { ptr @fld.str.461, i64 4 }, { ptr, i64 } { ptr @fld.str.462, i64 9 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.469 = private constant [10 x i8] c"exit_code\00" +@fld.str.470 = private constant [7 x i8] c"stdout\00" +@field_names.471 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 9 }, { ptr, i64 } { ptr @fld.str.470, i64 6 }] +@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.473 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.477 = private constant [8 x i8] c"sin_len\00" +@fld.str.478 = private constant [11 x i8] c"sin_family\00" +@fld.str.479 = private constant [9 x i8] c"sin_port\00" +@fld.str.480 = private constant [9 x i8] c"sin_addr\00" +@fld.str.481 = private constant [9 x i8] c"sin_zero\00" +@field_names.482 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 7 }, { ptr, i64 } { ptr @fld.str.478, i64 10 }, { ptr, i64 } { ptr @fld.str.479, i64 8 }, { ptr, i64 } { ptr @fld.str.480, i64 8 }, { ptr, i64 } { ptr @fld.str.481, i64 8 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.488 = private constant [6 x i8] c"items\00" +@fld.str.489 = private constant [4 x i8] c"len\00" +@fld.str.490 = private constant [4 x i8] c"cap\00" +@field_names.491 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 5 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 3 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.497 = private constant [6 x i8] c"items\00" +@fld.str.498 = private constant [4 x i8] c"len\00" +@fld.str.499 = private constant [4 x i8] c"cap\00" +@field_names.500 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.497, i64 5 }, { ptr, i64 } { ptr @fld.str.498, i64 3 }, { ptr, i64 } { ptr @fld.str.499, i64 3 }] +@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.502 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.504 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.505 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.506 = private constant [4 x i8] c"key\00" +@fld.str.507 = private constant [4 x i8] c"val\00" +@field_names.508 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.506, i64 3 }, { ptr, i64 } { ptr @fld.str.507, i64 3 }] +@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.510 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.514 = private constant [4 x i8] c"dst\00" +@fld.str.515 = private constant [4 x i8] c"pos\00" +@fld.str.516 = private constant [5 x i8] c"file\00" +@field_names.517 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 3 }, { ptr, i64 } { ptr @fld.str.515, i64 3 }, { ptr, i64 } { ptr @fld.str.516, i64 4 }] +@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.519 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.523 = private constant [4 x i8] c"src\00" +@fld.str.524 = private constant [4 x i8] c"pos\00" +@fld.str.525 = private constant [6 x i8] c"alloc\00" +@field_names.526 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 3 }, { ptr, i64 } { ptr @fld.str.524, i64 3 }, { ptr, i64 } { ptr @fld.str.525, i64 5 }] +@str.527 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.528 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.529 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.530 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.531 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.532 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.534 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.535 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.536 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.537 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.538 = private constant [5 x i8] c"name\00" +@fld.str.539 = private constant [12 x i8] c"takes_value\00" +@fld.str.540 = private constant [9 x i8] c"required\00" +@field_names.541 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 11 }, { ptr, i64 } { ptr @fld.str.540, i64 8 }] +@str.542 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.543 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.544 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.545 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.546 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.547 = private constant [6 x i8] c"group\00" +@fld.str.548 = private constant [8 x i8] c"command\00" +@fld.str.549 = private constant [6 x i8] c"flags\00" +@field_names.550 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.547, i64 5 }, { ptr, i64 } { ptr @fld.str.548, i64 7 }, { ptr, i64 } { ptr @fld.str.549, i64 5 }] +@str.551 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.552 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.553 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.555 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.556 = private constant [4 x i8] c"set\00" +@fld.str.557 = private constant [6 x i8] c"value\00" +@field_names.558 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 5 }] +@str.559 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.560 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.561 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.563 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.564 = private constant [6 x i8] c"index\00" +@fld.str.565 = private constant [6 x i8] c"token\00" +@field_names.566 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 5 }] +@str.567 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.568 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.569 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.571 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.572 = private constant [6 x i8] c"group\00" +@fld.str.573 = private constant [8 x i8] c"command\00" +@fld.str.574 = private constant [10 x i8] c"cmd_index\00" +@fld.str.575 = private constant [5 x i8] c"json\00" +@fld.str.576 = private constant [5 x i8] c"rest\00" +@fld.str.577 = private constant [5 x i8] c"spec\00" +@fld.str.578 = private constant [7 x i8] c"values\00" +@field_names.579 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 7 }, { ptr, i64 } { ptr @fld.str.574, i64 9 }, { ptr, i64 } { ptr @fld.str.575, i64 4 }, { ptr, i64 } { ptr @fld.str.576, i64 4 }, { ptr, i64 } { ptr @fld.str.577, i64 4 }, { ptr, i64 } { ptr @fld.str.578, i64 6 }] +@str.580 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.581 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.582 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.583 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.584 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.585 = private constant [2 x i8] c"h\00" +@fld.str.586 = private constant [4 x i8] c"buf\00" +@fld.str.587 = private constant [8 x i8] c"buf_len\00" +@fld.str.588 = private constant [10 x i8] c"total_len\00" +@field_names.589 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.585, i64 1 }, { ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 9 }] +@str.590 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.591 = private unnamed_addr constant [13 x i8] c"ProposedSize\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.594 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.595 = private constant [6 x i8] c"width\00" +@fld.str.596 = private constant [7 x i8] c"height\00" +@field_names.597 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.595, i64 5 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }] +@str.598 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.599 = private unnamed_addr constant [8 x i8] c"Sizable\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.602 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.603 = private constant [4 x i8] c"ctx\00" +@fld.str.604 = private constant [9 x i8] c"__vtable\00" +@field_names.605 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.603, i64 3 }, { ptr, i64 } { ptr @fld.str.604, i64 8 }] +@str.606 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.607 = private unnamed_addr constant [18 x i8] c"__Sizable__Vtable\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.611 = private constant [5 x i8] c"size\00" +@field_names.612 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.611, i64 4 }] +@str.613 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.614 = private unnamed_addr constant [7 x i8] c"Widget\00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.618 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.619 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.621 = private constant [5 x i8] c"read\00" +@fld.str.622 = private constant [6 x i8] c"write\00" +@fld.str.623 = private constant [7 x i8] c"append\00" +@fld.str.624 = private constant [11 x i8] c"read_write\00" +@field_names.625 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.621, i64 4 }, { ptr, i64 } { ptr @fld.str.622, i64 5 }, { ptr, i64 } { ptr @fld.str.623, i64 6 }, { ptr, i64 } { ptr @fld.str.624, i64 10 }] +@str.626 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.629 = private constant [4 x i8] c"set\00" +@fld.str.630 = private constant [8 x i8] c"current\00" +@fld.str.631 = private constant [4 x i8] c"end\00" +@field_names.632 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.629, i64 3 }, { ptr, i64 } { ptr @fld.str.630, i64 7 }, { ptr, i64 } { ptr @fld.str.631, i64 3 }] +@str.633 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.635 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.636 = private constant [6 x i8] c"null_\00" +@fld.str.637 = private constant [6 x i8] c"bool_\00" +@fld.str.638 = private constant [5 x i8] c"int_\00" +@fld.str.639 = private constant [4 x i8] c"str\00" +@fld.str.640 = private constant [6 x i8] c"array\00" +@fld.str.641 = private constant [7 x i8] c"object\00" +@field_names.642 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.636, i64 5 }, { ptr, i64 } { ptr @fld.str.637, i64 5 }, { ptr, i64 } { ptr @fld.str.638, i64 4 }, { ptr, i64 } { ptr @fld.str.639, i64 3 }, { ptr, i64 } { ptr @fld.str.640, i64 5 }, { ptr, i64 } { ptr @fld.str.641, i64 6 }] +@str.643 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.644 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.645 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.646 = private constant [6 x i8] c"macos\00" +@fld.str.647 = private constant [6 x i8] c"linux\00" +@fld.str.648 = private constant [8 x i8] c"windows\00" +@fld.str.649 = private constant [5 x i8] c"wasm\00" +@fld.str.650 = private constant [4 x i8] c"ios\00" +@fld.str.651 = private constant [8 x i8] c"android\00" +@fld.str.652 = private constant [8 x i8] c"unknown\00" +@field_names.653 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.646, i64 5 }, { ptr, i64 } { ptr @fld.str.647, i64 5 }, { ptr, i64 } { ptr @fld.str.648, i64 7 }, { ptr, i64 } { ptr @fld.str.649, i64 4 }, { ptr, i64 } { ptr @fld.str.650, i64 3 }, { ptr, i64 } { ptr @fld.str.651, i64 7 }, { ptr, i64 } { ptr @fld.str.652, i64 7 }] +@str.654 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.655 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.656 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.657 = private constant [8 x i8] c"aarch64\00" +@fld.str.658 = private constant [7 x i8] c"x86_64\00" +@fld.str.659 = private constant [7 x i8] c"wasm32\00" +@fld.str.660 = private constant [7 x i8] c"wasm64\00" +@fld.str.661 = private constant [8 x i8] c"unknown\00" +@field_names.662 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.657, i64 7 }, { ptr, i64 } { ptr @fld.str.658, i64 6 }, { ptr, i64 } { ptr @fld.str.659, i64 6 }, { ptr, i64 } { ptr @fld.str.660, i64 6 }, { ptr, i64 } { ptr @fld.str.661, i64 7 }] +@str.663 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.664 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.665 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.666 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.667 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.669 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.670 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.671 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.672 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.673 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.674 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.675 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.678 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.679 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.680 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.681 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.682 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.683 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.684 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.685 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.686 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.687 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.688 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.689 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.690 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.691 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.692 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.693 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.694 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.695 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.696 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.699 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.702 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.708 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.711 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.735 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.741 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.742 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.744 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.745 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.747 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.750 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.753 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.756 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.759 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.762 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.765 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.768 = private unnamed_addr constant [8 x i8] c"*Widget\00", align 1 +@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.771 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.774 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.777 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.780 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.783 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.786 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.787 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.789 = private unnamed_addr constant [14 x i8] c"*ProposedSize\00", align 1 +@str.790 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.791 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.792 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 +@str.793 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.795 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 +@str.796 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.798 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.799 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.800 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.801 = private unnamed_addr constant [9 x i8] c"*Sizable\00", align 1 +@str.802 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.803 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.804 = private unnamed_addr constant [9 x i8] c"**Widget\00", align 1 +@str.805 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.806 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.807 = private unnamed_addr constant [19 x i8] c"*__Sizable__Vtable\00", align 1 +@str.808 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.809 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.810 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.811 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.812 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.813 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -708,6 +708,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -927,7 +930,7 @@ entry: br i1 %icmp, label %if.then.68, label %if.merge.69 if.then.68: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.69: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1054,7 +1057,7 @@ if.else.91: ; preds = %entry br label %if.merge.92 if.merge.92: ; preds = %if.else.91, %if.then.90 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.90 ], [ { ptr @str.127, i64 5 }, %if.else.91 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.90 ], [ { ptr @str.129, i64 5 }, %if.else.91 ] ret { ptr, i64 } %bp } @@ -1388,7 +1391,7 @@ entry: br i1 %icmp, label %if.then.411, label %if.merge.412 if.then.411: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.412: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1538,7 +1541,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1564,9 +1567,9 @@ entry: i64 11, label %match.arm.54 i64 19, label %match.arm.55 i64 20, label %match.arm.55 - i64 22, label %match.arm.55 - i64 24, label %match.arm.55 - i64 26, label %match.arm.55 + i64 21, label %match.arm.55 + i64 23, label %match.arm.55 + i64 25, label %match.arm.55 i64 27, label %match.arm.55 i64 30, label %match.arm.55 i64 32, label %match.arm.55 @@ -1611,9 +1614,9 @@ entry: i64 85, label %match.arm.60 i64 102, label %match.arm.60 i64 18, label %match.arm.61 - i64 21, label %match.arm.61 - i64 23, label %match.arm.61 - i64 25, label %match.arm.61 + i64 22, label %match.arm.61 + i64 24, label %match.arm.61 + i64 26, label %match.arm.61 i64 28, label %match.arm.61 i64 29, label %match.arm.61 i64 31, label %match.arm.61 @@ -1660,7 +1663,7 @@ match.merge.49: ; preds = %dispatch.merge.532, ret { ptr, i64 } %loadN match.arm.50: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.49 match.arm.51: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1704,9 +1707,9 @@ match.arm.55: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.107 [ i64 19, label %dispatch.case.108 i64 20, label %dispatch.case.109 - i64 22, label %dispatch.case.110 - i64 24, label %dispatch.case.111 - i64 26, label %dispatch.case.112 + i64 21, label %dispatch.case.110 + i64 23, label %dispatch.case.111 + i64 25, label %dispatch.case.112 i64 27, label %dispatch.case.113 i64 30, label %dispatch.case.114 i64 32, label %dispatch.case.115 @@ -1791,9 +1794,9 @@ match.arm.61: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.370 [ i64 18, label %dispatch.case.371 - i64 21, label %dispatch.case.372 - i64 23, label %dispatch.case.373 - i64 25, label %dispatch.case.374 + i64 22, label %dispatch.case.372 + i64 24, label %dispatch.case.373 + i64 26, label %dispatch.case.374 i64 28, label %dispatch.case.375 i64 29, label %dispatch.case.376 i64 31, label %dispatch.case.377 @@ -1898,7 +1901,7 @@ dispatch.merge.106: ; preds = %dispatch.case.136, br label %match.merge.49 dispatch.default.107: ; preds = %match.arm.55 - store { ptr, i64 } { ptr @str.320, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.322, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.108: ; preds = %match.arm.55 @@ -1912,32 +1915,32 @@ dispatch.case.108: ; preds = %match.arm.55 dispatch.case.109: ; preds = %match.arm.55 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.110: ; preds = %match.arm.55 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.111: ; preds = %match.arm.55 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.112: ; preds = %match.arm.55 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 @@ -2139,7 +2142,7 @@ dispatch.merge.282: ; preds = %dispatch.case.288, br label %match.merge.49 dispatch.default.283: ; preds = %match.arm.56 - store { ptr, i64 } { ptr @str.321, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.282 dispatch.case.284: ; preds = %match.arm.56 @@ -2180,7 +2183,7 @@ dispatch.merge.299: ; preds = %dispatch.case.306, br label %match.merge.49 dispatch.default.300: ; preds = %match.arm.59 - store { ptr, i64 } { ptr @str.322, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.299 dispatch.case.301: ; preds = %match.arm.59 @@ -2237,7 +2240,7 @@ dispatch.merge.337: ; preds = %dispatch.case.343, br label %match.merge.49 dispatch.default.338: ; preds = %match.arm.60 - store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.337 dispatch.case.339: ; preds = %match.arm.60 @@ -2286,7 +2289,7 @@ dispatch.merge.369: ; preds = %dispatch.case.407, br label %match.merge.49 dispatch.default.370: ; preds = %match.arm.61 - store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.369 dispatch.case.371: ; preds = %match.arm.61 @@ -2554,7 +2557,7 @@ dispatch.merge.532: ; preds = %dispatch.case.538, br label %match.merge.49 dispatch.default.533: ; preds = %match.arm.62 - store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.532 dispatch.case.534: ; preds = %match.arm.62 @@ -2604,7 +2607,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.326, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.328, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2700,7 +2703,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2708,7 +2711,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2718,13 +2721,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2732,7 +2735,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2746,7 +2749,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2754,7 +2757,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2765,7 +2768,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2822,7 +2825,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2830,7 +2833,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2841,7 +2844,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2861,7 +2864,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2869,7 +2872,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, 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 @@ -2880,7 +2883,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2890,64 +2893,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3123,163 +3129,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3477,64 +3486,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3564,97 +3573,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3693,7 +3702,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal float @direct_size(ptr %0, { { float, i1 }, { float, i1 } } %1) #0 { @@ -3894,14 +3903,14 @@ entry: define internal void @print__ct_safaf8808e13137c9__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.341, i64 21 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.343, i64 21 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.342, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.344, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 21) @@ -3917,7 +3926,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.343, i64 21 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.345, i64 21 }) ret { ptr, i64 } %call } @@ -3925,7 +3934,7 @@ entry: define internal void @print__ct_sa9ba8ae6123c77ba__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.344, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.346, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3942,7 +3951,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.345, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.347, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -3971,7 +3980,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.346, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.348, i64 8 }) ret { ptr, i64 } %call } @@ -3979,7 +3988,7 @@ entry: define internal void @print__ct_s9af257f36f17eef5__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.347, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.349, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3996,7 +4005,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.348, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.350, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4025,7 +4034,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.349, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.351, i64 8 }) ret { ptr, i64 } %call } @@ -4033,7 +4042,7 @@ entry: define internal void @print__ct_scf4d64fa60dbbfb4__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.350, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.352, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4050,7 +4059,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.351, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.353, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4079,7 +4088,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_3(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.352, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.354, i64 8 }) ret { ptr, i64 } %call } @@ -4087,7 +4096,7 @@ entry: define internal void @print__ct_s1c39af9abf6a4a07__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.353, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.355, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4104,7 +4113,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.354, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.356, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4133,7 +4142,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_4(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.355, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.357, i64 8 }) ret { ptr, i64 } %call } @@ -4141,14 +4150,14 @@ entry: define internal void @print__ct_s1982bb0332b7dace__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.356, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.358, i64 26 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.357, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.359, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 26) @@ -4164,7 +4173,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_5(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.358, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.360, i64 26 }) ret { ptr, i64 } %call } @@ -4179,7 +4188,7 @@ entry: define internal void @print__ct_s328a3cec2430526b__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.359, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.361, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4196,7 +4205,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.360, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.362, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4225,7 +4234,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_6(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.361, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.363, i64 8 }) ret { ptr, i64 } %call } @@ -4233,7 +4242,7 @@ entry: define internal void @print__ct_sad2d86d80b81462__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.362, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.364, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4250,7 +4259,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.363, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.365, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4279,7 +4288,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_7(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.364, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.366, i64 8 }) ret { ptr, i64 } %call } @@ -4287,7 +4296,7 @@ entry: define internal void @print__ct_s356f7a97ffec319e__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.365, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.367, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4304,7 +4313,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.366, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.368, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4333,7 +4342,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_8(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.367, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.369, i64 8 }) ret { ptr, i64 } %call } @@ -4341,7 +4350,7 @@ entry: define internal void @print__ct_sc1a70412aecae073__pack_f32(ptr %0, float %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.368, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.370, i64 8 }, ptr %alloca, align 8 %allocaN = alloca float, align 4 store float %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -4358,7 +4367,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.369, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.371, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 5) @@ -4387,7 +4396,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_9(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.370, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.372, i64 8 }) ret { ptr, i64 } %call } @@ -4398,7 +4407,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.371, i64 15 }, { ptr, i64 } { ptr @str.372, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.373, i64 15 }, { ptr, i64 } { ptr @str.374, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4417,12 +4426,12 @@ while.body.138: ; preds = %while.hdr.137 while.exit.139: ; preds = %while.hdr.137 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 1 }) ret { ptr, i64 } %callN if.then.140: ; preds = %while.body.138 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.141 @@ -4434,7 +4443,7 @@ if.merge.141: ; preds = %if.then.140, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4487,20 +4496,20 @@ fv.case24: ; preds = %if.merge.141 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 10 }, { ptr, i64 } { ptr @str.380, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 9 }, { ptr, i64 } { ptr @str.382, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.142 -while.hdr.142: ; preds = %if.merge.146, %entry +while.hdr.142: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.143, label %while.exit.144 while.body.143: ; preds = %while.hdr.142 @@ -4510,224 +4519,24 @@ while.body.143: ; preds = %while.hdr.142 while.exit.144: ; preds = %while.hdr.142 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) ret { ptr, i64 } %callN if.then.145: ; preds = %while.body.143 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.146 if.merge.146: ; preds = %if.then.145, %while.body.143 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.383, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.388, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 3 }, { ptr, i64 } { ptr @str.386, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 - -while.hdr.147: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.148, label %while.exit.149 - -while.body.148: ; preds = %while.hdr.147 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 - -while.exit.149: ; preds = %while.hdr.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) - ret { ptr, i64 } %callN - -if.then.150: ; preds = %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 - -if.merge.151: ; preds = %if.then.150, %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.390, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.147 - -fv.default: ; preds = %if.merge.151 - br label %fv.merge - -fv.case: ; preds = %if.merge.151 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 10 }, { ptr, i64 } { ptr @str.393, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.152 - -while.hdr.152: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.153, label %while.exit.154 - -while.body.153: ; preds = %while.hdr.152 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.155, label %if.merge.156 - -while.exit.154: ; preds = %while.hdr.152 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) - ret { ptr, i64 } %callN - -if.then.155: ; preds = %while.body.153 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.156 - -if.merge.156: ; preds = %if.then.155, %while.body.153 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.398, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.152 - -fv.default: ; preds = %if.merge.156 - br label %fv.merge - -fv.case: ; preds = %if.merge.156 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.156 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 9 }, { ptr, i64 } { ptr @str.401, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.157 - -while.hdr.157: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.158, label %while.exit.159 - -while.body.158: ; preds = %while.hdr.157 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.160, label %if.merge.161 - -while.exit.159: ; preds = %while.hdr.157 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 1 }) - ret { ptr, i64 } %callN - -if.then.160: ; preds = %while.body.158 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.161 - -if.merge.161: ; preds = %if.then.160, %while.body.158 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, 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 @@ -4746,27 +4555,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.142 + +fv.default: ; preds = %if.merge.146 + br label %fv.merge + +fv.case: ; preds = %if.merge.146 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.146 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.146 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 10 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.147 + +while.hdr.147: ; preds = %if.merge.151, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.148, label %while.exit.149 + +while.body.148: ; preds = %while.hdr.147 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.150, label %if.merge.151 + +while.exit.149: ; preds = %while.hdr.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) + ret { ptr, i64 } %callN + +if.then.150: ; preds = %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.151 + +if.merge.151: ; preds = %if.then.150, %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.394, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.147 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.396, i64 3 }, { ptr, i64 } { ptr @str.397, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.152 + +while.hdr.152: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.153, label %while.exit.154 + +while.body.153: ; preds = %while.hdr.152 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.155, label %if.merge.156 + +while.exit.154: ; preds = %while.hdr.152 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 1 }) + ret { ptr, i64 } %callN + +if.then.155: ; preds = %while.body.153 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.156 + +if.merge.156: ; preds = %if.then.155, %while.body.153 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.401, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.152 + +fv.default: ; preds = %if.merge.156 + br label %fv.merge + +fv.case: ; preds = %if.merge.156 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.403, i64 10 }, { ptr, i64 } { ptr @str.404, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.157 + +while.hdr.157: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.158, label %while.exit.159 + +while.body.158: ; preds = %while.hdr.157 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.160, label %if.merge.161 + +while.exit.159: ; preds = %while.hdr.157 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 1 }) + ret { ptr, i64 } %callN + +if.then.160: ; preds = %while.body.158 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.161 + +if.merge.161: ; preds = %if.then.160, %while.body.158 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.157 fv.default: ; preds = %if.merge.161 br label %fv.merge fv.case: ; preds = %if.merge.161 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.161 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4776,7 +4785,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 5 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 5 }, { ptr, i64 } { ptr @str.412, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4795,24 +4804,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %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.416, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.418, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, 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 @@ -4839,7 +4848,7 @@ fv.default: ; preds = %if.merge.166 fv.case: ; preds = %if.merge.166 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 @@ -4851,7 +4860,7 @@ fv.case20: ; preds = %if.merge.166 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4860,7 +4869,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.418, i64 8 }, { ptr, i64 } { ptr @str.419, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.420, i64 8 }, { ptr, i64 } { ptr @str.421, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4879,24 +4888,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %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.425, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.427, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, 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 @@ -4943,7 +4952,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.427, i64 17 }, { ptr, i64 } { ptr @str.428, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 17 }, { ptr, i64 } { ptr @str.430, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4962,24 +4971,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.437, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5008,7 +5017,7 @@ fv.case: ; preds = %if.merge.176 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.176 @@ -5033,7 +5042,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 7 }, { ptr, i64 } { ptr @str.438, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 7 }, { ptr, i64 } { ptr @str.440, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5052,24 +5061,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %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.443, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.445, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, 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 @@ -5096,7 +5105,7 @@ fv.case: ; preds = %if.merge.181 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.181 @@ -5111,7 +5120,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 4 }, { ptr, i64 } { ptr @str.446, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 4 }, { ptr, i64 } { ptr @str.448, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5130,24 +5139,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %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.450, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.452, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -5184,7 +5193,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.452, i64 10 }, { ptr, i64 } { ptr @str.453, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 10 }, { ptr, i64 } { ptr @str.455, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5203,24 +5212,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.461, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.463, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5286,7 +5295,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 13 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 13 }, { ptr, i64 } { ptr @str.466, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5305,24 +5314,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %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.469, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.471, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5364,7 +5373,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 8 }, { ptr, i64 } { ptr @str.472, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 8 }, { ptr, i64 } { ptr @str.474, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5383,24 +5392,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.482, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5461,7 +5470,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 5 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 5 }, { ptr, i64 } { ptr @str.485, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5480,24 +5489,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, 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 @@ -5543,7 +5552,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 6 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 6 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5562,24 +5571,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.498, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.500, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, 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 @@ -5627,7 +5636,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 6 }, { ptr, i64 } { ptr @str.501, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 6 }, { ptr, i64 } { ptr @str.503, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5646,24 +5655,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.506, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.508, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5707,7 +5716,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 4 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 4 }, { ptr, i64 } { ptr @str.511, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5726,24 +5735,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.515, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.517, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5793,7 +5802,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 6 }, { ptr, i64 } { ptr @str.518, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 6 }, { ptr, i64 } { ptr @str.520, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5812,24 +5821,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.524, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.526, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5869,7 +5878,7 @@ fv.case20: ; preds = %if.merge.226 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5878,7 +5887,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 12 }, { ptr, i64 } { ptr @str.527, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.528, i64 12 }, { ptr, i64 } { ptr @str.529, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5897,24 +5906,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.530, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.532, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5934,7 +5943,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.532, i64 8 }, { ptr, i64 } { ptr @str.533, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 8 }, { ptr, i64 } { ptr @str.535, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5953,24 +5962,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.539, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.541, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -6022,7 +6031,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.541, i64 7 }, { ptr, i64 } { ptr @str.542, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.543, i64 7 }, { ptr, i64 } { ptr @str.544, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6041,24 +6050,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %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.548, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.550, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6110,7 +6119,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.550, i64 9 }, { ptr, i64 } { ptr @str.551, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.552, i64 9 }, { ptr, i64 } { ptr @str.553, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6129,24 +6138,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %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.556, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.558, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.559, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6189,7 +6198,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, i64 4 }, { ptr, i64 } { ptr @str.559, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 4 }, { ptr, i64 } { ptr @str.561, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6208,24 +6217,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %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.564, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.565, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.567, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6271,7 +6280,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.566, i64 6 }, { ptr, i64 } { ptr @str.567, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.568, i64 6 }, { ptr, i64 } { ptr @str.569, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6290,24 +6299,24 @@ while.body.253: ; preds = %while.hdr.252 while.exit.254: ; preds = %while.hdr.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) ret { ptr, i64 } %callN if.then.255: ; preds = %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 if.merge.256: ; preds = %if.then.255, %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.577, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.579, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -6389,7 +6398,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 6 }, { ptr, i64 } { ptr @str.580, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 6 }, { ptr, i64 } { ptr @str.582, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6408,24 +6417,24 @@ while.body.258: ; preds = %while.hdr.257 while.exit.259: ; preds = %while.hdr.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.583, i64 1 }) ret { ptr, i64 } %callN if.then.260: ; preds = %while.body.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.261 if.merge.261: ; preds = %if.then.260, %while.body.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.587, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6482,7 +6491,7 @@ entry: %ba.tmp = alloca { float, i1 }, align 8 %ba.tmp19 = alloca { float, i1 }, align 8 store { { float, i1 }, { float, i1 } } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.589, i64 12 }, { ptr, i64 } { ptr @str.590, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.591, i64 12 }, { ptr, i64 } { ptr @str.592, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6501,24 +6510,24 @@ while.body.263: ; preds = %while.hdr.262 while.exit.264: ; preds = %while.hdr.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) ret { ptr, i64 } %callN if.then.265: ; preds = %while.body.263 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.594, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 if.merge.266: ; preds = %if.then.265, %while.body.263 %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.595, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.597, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { float, i1 }, { float, i1 } }, ptr %alloca, align 4 @@ -6561,7 +6570,7 @@ define internal { ptr, i64 } @struct_to_string__Sizable(ptr %0, { ptr, ptr } %1) entry: %alloca = alloca { ptr, ptr }, align 8 store { ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 7 }, { ptr, i64 } { ptr @str.598, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 7 }, { ptr, i64 } { ptr @str.600, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6580,24 +6589,24 @@ while.body.268: ; preds = %while.hdr.267 while.exit.269: ; preds = %while.hdr.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 1 }) ret { ptr, i64 } %callN if.then.270: ; preds = %while.body.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.271 if.merge.271: ; preds = %if.then.270, %while.body.268 %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.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.605, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6638,7 +6647,7 @@ define internal { ptr, i64 } @struct_to_string____Sizable__Vtable(ptr %0, { ptr entry: %alloca = alloca { ptr }, align 8 store { ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.605, i64 17 }, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.607, i64 17 }, { ptr, i64 } { ptr @str.608, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6657,24 +6666,24 @@ while.body.273: ; preds = %while.hdr.272 while.exit.274: ; preds = %while.hdr.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) ret { ptr, i64 } %callN if.then.275: ; preds = %while.body.273 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.276 if.merge.276: ; preds = %if.then.275, %while.body.273 %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.610, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.612, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6708,7 +6717,7 @@ define internal { ptr, i64 } @struct_to_string__Widget(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.612, i64 6 }, { ptr, i64 } { ptr @str.613, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.614, i64 6 }, { ptr, i64 } { ptr @str.615, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6727,24 +6736,24 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %callN if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 if.merge.281: ; preds = %if.then.280, %while.body.278 %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.616, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.618, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6767,9 +6776,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.623, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.625, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.618, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.620, 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 @@ -6788,8 +6797,8 @@ entry: if.then.289: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.624, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.626, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6808,9 +6817,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.630, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.632, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.626, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, 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 @@ -6829,8 +6838,8 @@ entry: if.then.291: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.292 @@ -6860,9 +6869,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.640, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.642, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6879,8 +6888,8 @@ entry: if.then.293: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.644, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.294 @@ -6958,9 +6967,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.651, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.653, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, 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 @@ -6979,8 +6988,8 @@ entry: if.then.295: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.653, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.655, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6999,9 +7008,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.660, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.662, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, 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 @@ -7020,8 +7029,8 @@ entry: if.then.297: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.298 @@ -7038,7 +7047,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.663, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.665, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.307 @@ -7055,12 +7064,12 @@ while.body.308: ; preds = %while.hdr.307 while.exit.309: ; preds = %while.hdr.307 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 1 }) ret { ptr, i64 } %call if.then.310: ; preds = %while.body.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.311 @@ -7089,7 +7098,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.666, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.668, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.312 @@ -7106,12 +7115,12 @@ while.body.313: ; preds = %while.hdr.312 while.exit.314: ; preds = %while.hdr.312 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 1 }) ret { ptr, i64 } %call if.then.315: ; preds = %while.body.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.316 @@ -7141,7 +7150,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.669, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.671, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.317 @@ -7158,12 +7167,12 @@ while.body.318: ; preds = %while.hdr.317 while.exit.319: ; preds = %while.hdr.317 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 1 }) ret { ptr, i64 } %call if.then.320: ; preds = %while.body.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.321 @@ -7191,7 +7200,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.672, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.674, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.322 @@ -7208,12 +7217,12 @@ while.body.323: ; preds = %while.hdr.322 while.exit.324: ; preds = %while.hdr.322 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 1 }) ret { ptr, i64 } %call if.then.325: ; preds = %while.body.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.326 @@ -7242,7 +7251,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.675, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.677, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.327 @@ -7259,12 +7268,12 @@ while.body.328: ; preds = %while.hdr.327 while.exit.329: ; preds = %while.hdr.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 1 }) ret { ptr, i64 } %call if.then.330: ; preds = %while.body.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.331 @@ -7293,7 +7302,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.678, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.680, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -7310,12 +7319,12 @@ while.body.333: ; preds = %while.hdr.332 while.exit.334: ; preds = %while.hdr.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 1 }) ret { ptr, i64 } %call if.then.335: ; preds = %while.body.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.336 @@ -7345,7 +7354,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.681, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.683, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.344 @@ -7364,12 +7373,12 @@ while.body.345: ; preds = %while.hdr.344 while.exit.346: ; preds = %while.hdr.344 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 1 }) ret { ptr, i64 } %call if.then.347: ; preds = %while.body.345 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.348 @@ -7398,7 +7407,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.684, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.686, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.349 @@ -7417,12 +7426,12 @@ while.body.350: ; preds = %while.hdr.349 while.exit.351: ; preds = %while.hdr.349 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 1 }) ret { ptr, i64 } %call if.then.352: ; preds = %while.body.350 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.353 @@ -7451,7 +7460,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.687, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.689, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.354 @@ -7470,12 +7479,12 @@ while.body.355: ; preds = %while.hdr.354 while.exit.356: ; preds = %while.hdr.354 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 1 }) ret { ptr, i64 } %call if.then.357: ; preds = %while.body.355 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.358 @@ -7505,7 +7514,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.690, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.692, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.359 @@ -7524,12 +7533,12 @@ while.body.360: ; preds = %while.hdr.359 while.exit.361: ; preds = %while.hdr.359 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 1 }) ret { ptr, i64 } %call if.then.362: ; preds = %while.body.360 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.363 @@ -7559,7 +7568,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.693, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.695, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.364 @@ -7578,12 +7587,12 @@ while.body.365: ; preds = %while.hdr.364 while.exit.366: ; preds = %while.hdr.364 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 1 }) ret { ptr, i64 } %call if.then.367: ; preds = %while.body.365 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.368 @@ -7625,12 +7634,12 @@ if.then.408: ; preds = %entry if.else.409: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 5 }, { ptr, i64 } %callN) br label %if.merge.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7653,12 +7662,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 11 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7681,12 +7690,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 4 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7709,12 +7718,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 11 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7737,12 +7746,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 6 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7764,12 +7773,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 5 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7792,12 +7801,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 9 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7820,12 +7829,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 18 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7848,12 +7857,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 5 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7876,12 +7885,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7904,12 +7913,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 4 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7932,12 +7941,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 9 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7960,12 +7969,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 4 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7987,12 +7996,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 8 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -8015,12 +8024,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 6 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -8042,12 +8051,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 9 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -8070,12 +8079,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -8098,12 +8107,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 5 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -8126,12 +8135,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 7 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -8154,12 +8163,12 @@ if.then.478: ; preds = %entry if.else.479: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 4 }, { ptr, i64 } %callN) br label %if.merge.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -8182,12 +8191,12 @@ if.then.481: ; preds = %entry if.else.482: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 7 }, { ptr, i64 } %callN) br label %if.merge.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -8210,12 +8219,12 @@ if.then.484: ; preds = %entry if.else.485: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 5 }, { ptr, i64 } %callN) br label %if.merge.486 if.merge.486: ; preds = %if.else.485, %if.then.484 - %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -8238,12 +8247,12 @@ if.then.487: ; preds = %entry if.else.488: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 7 }, { ptr, i64 } %callN) br label %if.merge.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -8266,12 +8275,12 @@ if.then.490: ; preds = %entry if.else.491: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 7 }, { ptr, i64 } %callN) br label %if.merge.492 if.merge.492: ; preds = %if.else.491, %if.then.490 - %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -8294,12 +8303,12 @@ if.then.493: ; preds = %entry if.else.494: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 12 }, { ptr, i64 } %callN) br label %if.merge.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -8322,12 +8331,12 @@ if.then.496: ; preds = %entry if.else.497: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 6 }, { ptr, i64 } %callN) br label %if.merge.498 if.merge.498: ; preds = %if.else.497, %if.then.496 - %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -8350,12 +8359,12 @@ if.then.499: ; preds = %entry if.else.500: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 7 }, { ptr, i64 } %callN) br label %if.merge.501 if.merge.501: ; preds = %if.else.500, %if.then.499 - %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -8378,12 +8387,12 @@ if.then.502: ; preds = %entry if.else.503: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 4 }, { ptr, i64 } %callN) br label %if.merge.504 if.merge.504: ; preds = %if.else.503, %if.then.502 - %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] + %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] ret { ptr, i64 } %bp } @@ -8406,12 +8415,12 @@ if.then.505: ; preds = %entry if.else.506: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 6 }, { ptr, i64 } %callN) br label %if.merge.507 if.merge.507: ; preds = %if.else.506, %if.then.505 - %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] + %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] ret { ptr, i64 } %bp } @@ -8434,12 +8443,12 @@ if.then.508: ; preds = %entry if.else.509: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 5 }, { ptr, i64 } %callN) br label %if.merge.510 if.merge.510: ; preds = %if.else.509, %if.then.508 - %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] + %bp = phi { ptr, i64 } [ { ptr @str.785, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] ret { ptr, i64 } %bp } @@ -8462,12 +8471,12 @@ if.then.511: ; preds = %entry if.else.512: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 13 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 13 }, { ptr, i64 } %callN) br label %if.merge.513 if.merge.513: ; preds = %if.else.512, %if.then.511 - %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] + %bp = phi { ptr, i64 } [ { ptr @str.788, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] ret { ptr, i64 } %bp } @@ -8490,12 +8499,12 @@ if.then.514: ; preds = %entry if.else.515: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 4 }, { ptr, i64 } %callN) br label %if.merge.516 if.merge.516: ; preds = %if.else.515, %if.then.514 - %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] + %bp = phi { ptr, i64 } [ { ptr @str.791, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] ret { ptr, i64 } %bp } @@ -8518,12 +8527,12 @@ if.then.517: ; preds = %entry if.else.518: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 4 }, { ptr, i64 } %callN) br label %if.merge.519 if.merge.519: ; preds = %if.else.518, %if.then.517 - %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] + %bp = phi { ptr, i64 } [ { ptr @str.794, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] ret { ptr, i64 } %bp } @@ -8546,12 +8555,12 @@ if.then.520: ; preds = %entry if.else.521: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 7 }, { ptr, i64 } %callN) br label %if.merge.522 if.merge.522: ; preds = %if.else.521, %if.then.520 - %bp = phi { ptr, i64 } [ { ptr @str.795, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] + %bp = phi { ptr, i64 } [ { ptr @str.797, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] ret { ptr, i64 } %bp } @@ -8574,12 +8583,12 @@ if.then.523: ; preds = %entry if.else.524: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 8 }, { ptr, i64 } %callN) br label %if.merge.525 if.merge.525: ; preds = %if.else.524, %if.then.523 - %bp = phi { ptr, i64 } [ { ptr @str.798, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] + %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] ret { ptr, i64 } %bp } @@ -8602,12 +8611,12 @@ if.then.526: ; preds = %entry if.else.527: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 8 }, { ptr, i64 } %callN) br label %if.merge.528 if.merge.528: ; preds = %if.else.527, %if.then.526 - %bp = phi { ptr, i64 } [ { ptr @str.801, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] + %bp = phi { ptr, i64 } [ { ptr @str.803, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] ret { ptr, i64 } %bp } @@ -8630,12 +8639,12 @@ if.then.529: ; preds = %entry if.else.530: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 18 }, { ptr, i64 } %callN) br label %if.merge.531 if.merge.531: ; preds = %if.else.530, %if.then.529 - %bp = phi { ptr, i64 } [ { ptr @str.804, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] + %bp = phi { ptr, i64 } [ { ptr @str.806, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] ret { ptr, i64 } %bp } @@ -8651,7 +8660,7 @@ entry: br i1 %lnot, label %if.then.539, label %if.merge.540 if.then.539: ; preds = %entry - ret { ptr, i64 } { ptr @str.807, i64 4 } + ret { ptr, i64 } { ptr @str.809, i64 4 } if.merge.540: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8675,7 +8684,7 @@ entry: br i1 %lnot, label %if.then.541, label %if.merge.542 if.then.541: ; preds = %entry - ret { ptr, i64 } { ptr @str.808, i64 4 } + ret { ptr, i64 } { ptr @str.810, i64 4 } if.merge.542: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8699,7 +8708,7 @@ entry: br i1 %lnot, label %if.then.543, label %if.merge.544 if.then.543: ; preds = %entry - ret { ptr, i64 } { ptr @str.809, i64 4 } + ret { ptr, i64 } { ptr @str.811, i64 4 } if.merge.544: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8723,7 +8732,7 @@ entry: br i1 %lnot, label %if.then.545, label %if.merge.546 if.then.545: ; preds = %entry - ret { ptr, i64 } { ptr @str.810, i64 4 } + ret { ptr, i64 } { ptr @str.812, i64 4 } if.merge.546: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -8746,7 +8755,7 @@ entry: br i1 %lnot, label %if.then.547, label %if.merge.548 if.then.547: ; preds = %entry - ret { ptr, i64 } { ptr @str.811, i64 4 } + ret { ptr, i64 } { ptr @str.813, i64 4 } if.merge.548: ; preds = %entry %loadN = load { float, i1 }, ptr %alloca, align 4 diff --git a/examples/expected/0904-optionals-any-to-string-optional.ir b/examples/expected/0904-optionals-any-to-string-optional.ir index 849e703..d3a5108 100644 --- a/examples/expected/0904-optionals-any-to-string-optional.ir +++ b/examples/expected/0904-optionals-any-to-string-optional.ir @@ -1,626 +1,626 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [166 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.144 = private constant [5 x i8] c"bool\00" -@tn.str.145 = private constant [3 x i8] c"s8\00" -@tn.str.146 = private constant [4 x i8] c"s16\00" -@tn.str.147 = private constant [4 x i8] c"s32\00" -@tn.str.148 = private constant [4 x i8] c"s64\00" -@tn.str.149 = private constant [3 x i8] c"u8\00" -@tn.str.150 = private constant [4 x i8] c"u16\00" -@tn.str.151 = private constant [4 x i8] c"u32\00" -@tn.str.152 = private constant [4 x i8] c"u64\00" -@tn.str.153 = private constant [4 x i8] c"f32\00" -@tn.str.154 = private constant [4 x i8] c"f64\00" -@tn.str.155 = private constant [7 x i8] c"string\00" -@tn.str.156 = private constant [4 x i8] c"Any\00" -@tn.str.157 = private constant [9 x i8] c"noreturn\00" -@tn.str.158 = private constant [6 x i8] c"isize\00" -@tn.str.159 = private constant [6 x i8] c"usize\00" -@tn.str.160 = private constant [5 x i8] c"void\00" -@tn.str.161 = private constant [6 x i8] c"*void\00" -@tn.str.162 = private constant [16 x i8] c"Source_Location\00" -@tn.str.163 = private constant [11 x i8] c"CAllocator\00" -@tn.str.164 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.165 = private constant [4 x i8] c"GPA\00" -@tn.str.166 = private constant [5 x i8] c"*GPA\00" -@tn.str.167 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.168 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.169 = private constant [10 x i8] c"Allocator\00" -@tn.str.170 = private constant [6 x i8] c"Arena\00" -@tn.str.171 = private constant [7 x i8] c"*Arena\00" -@tn.str.172 = private constant [6 x i8] c"[*]u8\00" -@tn.str.173 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.174 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.175 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.176 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.177 = private constant [8 x i8] c"Context\00" -@tn.str.178 = private constant [7 x i8] c"[4]s64\00" -@tn.str.179 = private constant [9 x i8] c"[]string\00" -@tn.str.180 = private constant [9 x i8] c"OpenMode\00" -@tn.str.181 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.182 = private constant [5 x i8] c"File\00" -@tn.str.183 = private constant [6 x i8] c"*File\00" -@tn.str.184 = private constant [6 x i8] c"?File\00" -@tn.str.185 = private constant [8 x i8] c"?string\00" -@tn.str.186 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.187 = private constant [4 x i8] c"*u8\00" -@tn.str.188 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.189 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.190 = private constant [5 x i8] c"*s32\00" -@tn.str.191 = private constant [9 x i8] c"SockAddr\00" -@tn.str.192 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.193 = private constant [5 x i8] c"*u32\00" -@tn.str.194 = private constant [10 x i8] c"JsonError\00" -@tn.str.195 = private constant [6 x i8] c"Array\00" -@tn.str.196 = private constant [7 x i8] c"Object\00" -@tn.str.197 = private constant [6 x i8] c"Value\00" -@tn.str.198 = private constant [7 x i8] c"Member\00" -@tn.str.199 = private constant [9 x i8] c"[*]Value\00" -@tn.str.200 = private constant [7 x i8] c"*Array\00" -@tn.str.201 = private constant [10 x i8] c"[*]Member\00" -@tn.str.202 = private constant [8 x i8] c"*Object\00" -@tn.str.203 = private constant [5 x i8] c"[]u8\00" -@tn.str.204 = private constant [5 x i8] c"Sink\00" -@tn.str.205 = private constant [6 x i8] c"*Sink\00" -@tn.str.206 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.207 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.208 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.209 = private constant [7 x i8] c"Parser\00" -@tn.str.210 = private constant [8 x i8] c"*Parser\00" -@tn.str.211 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.212 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.213 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.214 = private constant [13 x i8] c"Architecture\00" -@tn.str.215 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.216 = private constant [11 x i8] c"() -> bool\00" -@tn.str.217 = private constant [5 x i8] c"*s64\00" -@tn.str.218 = private constant [9 x i8] c"CliError\00" -@tn.str.219 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.220 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.221 = private constant [8 x i8] c"Command\00" -@tn.str.222 = private constant [10 x i8] c"FlagValue\00" -@tn.str.223 = private constant [5 x i8] c"Diag\00" -@tn.str.224 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.225 = private constant [7 x i8] c"Parsed\00" -@tn.str.226 = private constant [8 x i8] c"*Parsed\00" -@tn.str.227 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.228 = private constant [10 x i8] c"[]Command\00" -@tn.str.229 = private constant [6 x i8] c"*Diag\00" -@tn.str.230 = private constant [7 x i8] c"[8]s64\00" -@tn.str.231 = private constant [7 x i8] c"[64]u8\00" -@tn.str.232 = private constant [7 x i8] c"Sha256\00" -@tn.str.233 = private constant [8 x i8] c"*Sha256\00" -@tn.str.234 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.235 = private constant [8 x i8] c"[64]s64\00" -@tn.str.236 = private constant [5 x i8] c"?s64\00" -@tn.str.237 = private constant [6 x i8] c"?bool\00" -@tn.str.238 = private constant [2 x i8] c"S\00" -@tn.str.239 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.240 = private constant [7 x i8] c"**void\00" -@tn.str.241 = private constant [3 x i8] c"*S\00" -@tn.str.242 = private constant [8 x i8] c"*string\00" -@tn.str.243 = private constant [6 x i8] c"[]Any\00" -@tn.str.244 = private constant [5 x i8] c"*Any\00" -@tn.str.245 = private constant [7 x i8] c"[1]Any\00" -@tn.str.246 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.247 = private constant [7 x i8] c"*[]Any\00" -@tn.str.248 = private constant [6 x i8] c"*bool\00" -@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.250 = private constant [5 x i8] c"*f64\00" -@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.252 = private constant [11 x i8] c"*Allocator\00" -@tn.str.253 = private constant [9 x i8] c"*Context\00" -@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.256 = private constant [8 x i8] c"*Member\00" -@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.259 = private constant [9 x i8] c"*Command\00" -@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.263 = private constant [7 x i8] c"*Value\00" -@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.265 = private constant [14 x i8] c"*Architecture\00" -@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.270 = private constant [10 x i8] c"*[]string\00" -@tn.str.271 = private constant [6 x i8] c"*[]u8\00" -@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.273 = private constant [11 x i8] c"*[]Command\00" -@tn.str.274 = private constant [6 x i8] c"**GPA\00" -@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.276 = private constant [8 x i8] c"**Arena\00" -@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.280 = private constant [7 x i8] c"**File\00" -@tn.str.281 = private constant [5 x i8] c"**u8\00" -@tn.str.282 = private constant [6 x i8] c"**s32\00" -@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.284 = private constant [6 x i8] c"**u32\00" -@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.286 = private constant [8 x i8] c"**Array\00" -@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.288 = private constant [9 x i8] c"**Object\00" -@tn.str.289 = private constant [7 x i8] c"**Sink\00" -@tn.str.290 = private constant [9 x i8] c"**Parser\00" -@tn.str.291 = private constant [6 x i8] c"**s64\00" -@tn.str.292 = private constant [9 x i8] c"**Parsed\00" -@tn.str.293 = private constant [7 x i8] c"**Diag\00" -@tn.str.294 = private constant [9 x i8] c"**Sha256\00" -@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.296 = private constant [8 x i8] c"***void\00" -@tn.str.297 = private constant [4 x i8] c"**S\00" -@tn.str.298 = private constant [9 x i8] c"**string\00" -@tn.str.299 = private constant [6 x i8] c"**Any\00" -@tn.str.300 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.301 = private constant [8 x i8] c"**[]Any\00" -@tn.str.302 = private constant [7 x i8] c"**bool\00" -@tn.str.303 = private constant [7 x i8] c"*?File\00" -@tn.str.304 = private constant [9 x i8] c"*?string\00" -@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" -@tn.str.307 = private constant [6 x i8] c"*?s64\00" -@tn.str.308 = private constant [7 x i8] c"*?bool\00" -@__sx_type_names = private constant [166 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.144, i64 4 }, { ptr, i64 } { ptr @tn.str.145, i64 2 }, { ptr, i64 } { ptr @tn.str.146, i64 3 }, { ptr, i64 } { ptr @tn.str.147, i64 3 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 6 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 8 }, { ptr, i64 } { ptr @tn.str.158, i64 5 }, { ptr, i64 } { ptr @tn.str.159, i64 5 }, { ptr, i64 } { ptr @tn.str.160, i64 4 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 15 }, { ptr, i64 } { ptr @tn.str.163, i64 10 }, { ptr, i64 } { ptr @tn.str.164, i64 11 }, { ptr, i64 } { ptr @tn.str.165, i64 3 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 10 }, { ptr, i64 } { ptr @tn.str.168, i64 11 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 5 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 9 }, { ptr, i64 } { ptr @tn.str.175, i64 17 }, { ptr, i64 } { ptr @tn.str.176, i64 18 }, { ptr, i64 } { ptr @tn.str.177, i64 7 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 8 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 4 }, { ptr, i64 } { ptr @tn.str.183, i64 5 }, { ptr, i64 } { ptr @tn.str.184, i64 5 }, { ptr, i64 } { ptr @tn.str.185, i64 7 }, { ptr, i64 } { ptr @tn.str.186, i64 10 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 13 }, { ptr, i64 } { ptr @tn.str.189, i64 14 }, { ptr, i64 } { ptr @tn.str.190, i64 4 }, { ptr, i64 } { ptr @tn.str.191, i64 8 }, { ptr, i64 } { ptr @tn.str.192, i64 9 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 8 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 7 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 4 }, { ptr, i64 } { ptr @tn.str.205, i64 5 }, { ptr, i64 } { ptr @tn.str.206, i64 16 }, { ptr, i64 } { ptr @tn.str.207, i64 14 }, { ptr, i64 } { ptr @tn.str.208, i64 21 }, { ptr, i64 } { ptr @tn.str.209, i64 6 }, { ptr, i64 } { ptr @tn.str.210, i64 7 }, { ptr, i64 } { ptr @tn.str.211, i64 24 }, { ptr, i64 } { ptr @tn.str.212, i64 23 }, { ptr, i64 } { ptr @tn.str.213, i64 15 }, { ptr, i64 } { ptr @tn.str.214, i64 12 }, { ptr, i64 } { ptr @tn.str.215, i64 12 }, { ptr, i64 } { ptr @tn.str.216, i64 10 }, { ptr, i64 } { ptr @tn.str.217, i64 4 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 7 }, { ptr, i64 } { ptr @tn.str.222, i64 9 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 13 }, { ptr, i64 } { ptr @tn.str.225, i64 6 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 18 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 5 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 7 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 4 }, { ptr, i64 } { ptr @tn.str.237, i64 5 }, { ptr, i64 } { ptr @tn.str.238, i64 1 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 2 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 5 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 3 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 7 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 5 }, { ptr, i64 } { ptr @tn.str.308, i64 6 }] -@str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.146 = private constant [5 x i8] c"bool\00" +@tn.str.147 = private constant [3 x i8] c"s8\00" +@tn.str.148 = private constant [4 x i8] c"s16\00" +@tn.str.149 = private constant [4 x i8] c"s32\00" +@tn.str.150 = private constant [4 x i8] c"s64\00" +@tn.str.151 = private constant [3 x i8] c"u8\00" +@tn.str.152 = private constant [4 x i8] c"u16\00" +@tn.str.153 = private constant [4 x i8] c"u32\00" +@tn.str.154 = private constant [4 x i8] c"u64\00" +@tn.str.155 = private constant [4 x i8] c"f32\00" +@tn.str.156 = private constant [4 x i8] c"f64\00" +@tn.str.157 = private constant [7 x i8] c"string\00" +@tn.str.158 = private constant [4 x i8] c"Any\00" +@tn.str.159 = private constant [9 x i8] c"noreturn\00" +@tn.str.160 = private constant [6 x i8] c"isize\00" +@tn.str.161 = private constant [6 x i8] c"usize\00" +@tn.str.162 = private constant [5 x i8] c"void\00" +@tn.str.163 = private constant [6 x i8] c"*void\00" +@tn.str.164 = private constant [16 x i8] c"Source_Location\00" +@tn.str.165 = private constant [10 x i8] c"Allocator\00" +@tn.str.166 = private constant [11 x i8] c"CAllocator\00" +@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.168 = private constant [4 x i8] c"GPA\00" +@tn.str.169 = private constant [5 x i8] c"*GPA\00" +@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.172 = private constant [6 x i8] c"Arena\00" +@tn.str.173 = private constant [7 x i8] c"*Arena\00" +@tn.str.174 = private constant [6 x i8] c"[*]u8\00" +@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.179 = private constant [8 x i8] c"Context\00" +@tn.str.180 = private constant [7 x i8] c"[4]s64\00" +@tn.str.181 = private constant [9 x i8] c"[]string\00" +@tn.str.182 = private constant [9 x i8] c"OpenMode\00" +@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.184 = private constant [5 x i8] c"File\00" +@tn.str.185 = private constant [6 x i8] c"*File\00" +@tn.str.186 = private constant [6 x i8] c"?File\00" +@tn.str.187 = private constant [8 x i8] c"?string\00" +@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.189 = private constant [4 x i8] c"*u8\00" +@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.192 = private constant [5 x i8] c"*s32\00" +@tn.str.193 = private constant [9 x i8] c"SockAddr\00" +@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.195 = private constant [5 x i8] c"*u32\00" +@tn.str.196 = private constant [10 x i8] c"JsonError\00" +@tn.str.197 = private constant [6 x i8] c"Array\00" +@tn.str.198 = private constant [7 x i8] c"Object\00" +@tn.str.199 = private constant [6 x i8] c"Value\00" +@tn.str.200 = private constant [7 x i8] c"Member\00" +@tn.str.201 = private constant [9 x i8] c"[*]Value\00" +@tn.str.202 = private constant [7 x i8] c"*Array\00" +@tn.str.203 = private constant [10 x i8] c"[*]Member\00" +@tn.str.204 = private constant [8 x i8] c"*Object\00" +@tn.str.205 = private constant [5 x i8] c"[]u8\00" +@tn.str.206 = private constant [5 x i8] c"Sink\00" +@tn.str.207 = private constant [6 x i8] c"*Sink\00" +@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.211 = private constant [7 x i8] c"Parser\00" +@tn.str.212 = private constant [8 x i8] c"*Parser\00" +@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.216 = private constant [13 x i8] c"Architecture\00" +@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.218 = private constant [11 x i8] c"() -> bool\00" +@tn.str.219 = private constant [5 x i8] c"*s64\00" +@tn.str.220 = private constant [9 x i8] c"CliError\00" +@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.223 = private constant [8 x i8] c"Command\00" +@tn.str.224 = private constant [10 x i8] c"FlagValue\00" +@tn.str.225 = private constant [5 x i8] c"Diag\00" +@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.227 = private constant [7 x i8] c"Parsed\00" +@tn.str.228 = private constant [8 x i8] c"*Parsed\00" +@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.230 = private constant [10 x i8] c"[]Command\00" +@tn.str.231 = private constant [6 x i8] c"*Diag\00" +@tn.str.232 = private constant [7 x i8] c"[8]s64\00" +@tn.str.233 = private constant [7 x i8] c"[64]u8\00" +@tn.str.234 = private constant [7 x i8] c"Sha256\00" +@tn.str.235 = private constant [8 x i8] c"*Sha256\00" +@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.237 = private constant [8 x i8] c"[64]s64\00" +@tn.str.238 = private constant [5 x i8] c"?s64\00" +@tn.str.239 = private constant [6 x i8] c"?bool\00" +@tn.str.240 = private constant [2 x i8] c"S\00" +@tn.str.241 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.242 = private constant [7 x i8] c"**void\00" +@tn.str.243 = private constant [3 x i8] c"*S\00" +@tn.str.244 = private constant [8 x i8] c"*string\00" +@tn.str.245 = private constant [6 x i8] c"[]Any\00" +@tn.str.246 = private constant [5 x i8] c"*Any\00" +@tn.str.247 = private constant [7 x i8] c"[1]Any\00" +@tn.str.248 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.249 = private constant [7 x i8] c"*[]Any\00" +@tn.str.250 = private constant [6 x i8] c"*bool\00" +@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.252 = private constant [5 x i8] c"*f64\00" +@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.254 = private constant [11 x i8] c"*Allocator\00" +@tn.str.255 = private constant [9 x i8] c"*Context\00" +@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.258 = private constant [8 x i8] c"*Member\00" +@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.261 = private constant [9 x i8] c"*Command\00" +@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.265 = private constant [7 x i8] c"*Value\00" +@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.267 = private constant [14 x i8] c"*Architecture\00" +@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.272 = private constant [10 x i8] c"*[]string\00" +@tn.str.273 = private constant [6 x i8] c"*[]u8\00" +@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.275 = private constant [11 x i8] c"*[]Command\00" +@tn.str.276 = private constant [6 x i8] c"**GPA\00" +@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.278 = private constant [8 x i8] c"**Arena\00" +@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.282 = private constant [7 x i8] c"**File\00" +@tn.str.283 = private constant [5 x i8] c"**u8\00" +@tn.str.284 = private constant [6 x i8] c"**s32\00" +@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.286 = private constant [6 x i8] c"**u32\00" +@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.288 = private constant [8 x i8] c"**Array\00" +@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.290 = private constant [9 x i8] c"**Object\00" +@tn.str.291 = private constant [7 x i8] c"**Sink\00" +@tn.str.292 = private constant [9 x i8] c"**Parser\00" +@tn.str.293 = private constant [6 x i8] c"**s64\00" +@tn.str.294 = private constant [9 x i8] c"**Parsed\00" +@tn.str.295 = private constant [7 x i8] c"**Diag\00" +@tn.str.296 = private constant [9 x i8] c"**Sha256\00" +@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.298 = private constant [8 x i8] c"***void\00" +@tn.str.299 = private constant [4 x i8] c"**S\00" +@tn.str.300 = private constant [9 x i8] c"**string\00" +@tn.str.301 = private constant [6 x i8] c"**Any\00" +@tn.str.302 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.303 = private constant [8 x i8] c"**[]Any\00" +@tn.str.304 = private constant [7 x i8] c"**bool\00" +@tn.str.305 = private constant [7 x i8] c"*?File\00" +@tn.str.306 = private constant [9 x i8] c"*?string\00" +@tn.str.307 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.308 = private constant [9 x i8] c"*?[64]u8\00" +@tn.str.309 = private constant [6 x i8] c"*?s64\00" +@tn.str.310 = private constant [7 x i8] c"*?bool\00" +@__sx_type_names = private constant [166 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 9 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 4 }, { ptr, i64 } { ptr @tn.str.239, i64 5 }, { ptr, i64 } { ptr @tn.str.240, i64 1 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 2 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 3 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 15 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 5 }, { ptr, i64 } { ptr @tn.str.310, i64 6 }] @str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.315 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.316 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.317 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.318 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.319 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.320 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.324 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.325 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.326 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.327 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.328 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.329 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.330 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 -@str.331 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.315 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.316 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.317 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.321 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.322 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.326 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.327 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.328 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.329 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.330 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.331 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.332 = private unnamed_addr constant [3 x i8] c"hi\00", align 1 @str.333 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.334 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.335 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.336 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.337 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.335 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.336 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.337 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.338 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.338 = private constant [5 x i8] c"line\00" -@fld.str.339 = private constant [4 x i8] c"col\00" -@fld.str.340 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.338, i64 4 }, { ptr, i64 } { ptr @fld.str.339, i64 3 }, { ptr, i64 } { ptr @fld.str.340, i64 4 }] -@str.341 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.342 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.343 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.344 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.345 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.346 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.347 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.348 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.349 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.350 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.351 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.352 = private constant [12 x i8] c"alloc_count\00" -@field_names.353 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.352, i64 11 }] -@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.355 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.359 = private constant [5 x i8] c"next\00" -@fld.str.360 = private constant [4 x i8] c"cap\00" -@field_names.361 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 4 }, { ptr, i64 } { ptr @fld.str.360, i64 3 }] -@str.362 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.363 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.364 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.366 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.367 = private constant [4 x i8] c"ctx\00" -@fld.str.368 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.369 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.370 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.367, i64 3 }, { ptr, i64 } { ptr @fld.str.368, i64 11 }, { ptr, i64 } { ptr @fld.str.369, i64 13 }] -@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.372 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.374 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.375 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.376 = private constant [6 x i8] c"first\00" -@fld.str.377 = private constant [10 x i8] c"end_index\00" -@fld.str.378 = private constant [7 x i8] c"parent\00" -@field_names.379 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.376, i64 5 }, { ptr, i64 } { ptr @fld.str.377, i64 9 }, { ptr, i64 } { ptr @fld.str.378, i64 6 }] -@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.381 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.385 = private constant [4 x i8] c"buf\00" -@fld.str.386 = private constant [4 x i8] c"len\00" -@fld.str.387 = private constant [4 x i8] c"pos\00" -@field_names.388 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 3 }, { ptr, i64 } { ptr @fld.str.386, i64 3 }, { ptr, i64 } { ptr @fld.str.387, i64 3 }] -@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.390 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.394 = private constant [7 x i8] c"parent\00" -@fld.str.395 = private constant [12 x i8] c"alloc_count\00" -@fld.str.396 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.397 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.398 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 6 }, { ptr, i64 } { ptr @fld.str.395, i64 11 }, { ptr, i64 } { ptr @fld.str.396, i64 13 }, { ptr, i64 } { ptr @fld.str.397, i64 17 }] -@str.399 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.400 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.401 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.402 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.403 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.404 = private constant [10 x i8] c"allocator\00" -@fld.str.405 = private constant [5 x i8] c"data\00" -@field_names.406 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.404, i64 9 }, { ptr, i64 } { ptr @fld.str.405, i64 4 }] -@str.407 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.408 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.409 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.411 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.412 = private constant [3 x i8] c"fd\00" -@field_names.413 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.412, i64 2 }] -@str.414 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.415 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.416 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.417 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.418 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.419 = private constant [5 x i8] c"file\00" -@fld.str.420 = private constant [5 x i8] c"line\00" -@fld.str.421 = private constant [4 x i8] c"col\00" -@fld.str.422 = private constant [5 x i8] c"func\00" -@fld.str.423 = private constant [10 x i8] c"line_text\00" -@field_names.424 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.419, i64 4 }, { ptr, i64 } { ptr @fld.str.420, i64 4 }, { ptr, i64 } { ptr @fld.str.421, i64 3 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 9 }] -@str.425 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.426 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.427 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.428 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.429 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.430 = private constant [10 x i8] c"exit_code\00" -@fld.str.431 = private constant [7 x i8] c"stdout\00" -@field_names.432 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.430, i64 9 }, { ptr, i64 } { ptr @fld.str.431, i64 6 }] -@str.433 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.434 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.435 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.436 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.437 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.438 = private constant [8 x i8] c"sin_len\00" -@fld.str.439 = private constant [11 x i8] c"sin_family\00" -@fld.str.440 = private constant [9 x i8] c"sin_port\00" -@fld.str.441 = private constant [9 x i8] c"sin_addr\00" -@fld.str.442 = private constant [9 x i8] c"sin_zero\00" -@field_names.443 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.438, i64 7 }, { ptr, i64 } { ptr @fld.str.439, i64 10 }, { ptr, i64 } { ptr @fld.str.440, i64 8 }, { ptr, i64 } { ptr @fld.str.441, i64 8 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }] -@str.444 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.445 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.446 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.447 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.448 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.449 = private constant [6 x i8] c"items\00" -@fld.str.450 = private constant [4 x i8] c"len\00" -@fld.str.451 = private constant [4 x i8] c"cap\00" -@field_names.452 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.449, i64 5 }, { ptr, i64 } { ptr @fld.str.450, i64 3 }, { ptr, i64 } { ptr @fld.str.451, i64 3 }] -@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.454 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.458 = private constant [6 x i8] c"items\00" -@fld.str.459 = private constant [4 x i8] c"len\00" -@fld.str.460 = private constant [4 x i8] c"cap\00" -@field_names.461 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 5 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }] -@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.463 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.467 = private constant [4 x i8] c"key\00" -@fld.str.468 = private constant [4 x i8] c"val\00" -@field_names.469 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 3 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }] -@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.471 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.475 = private constant [4 x i8] c"dst\00" -@fld.str.476 = private constant [4 x i8] c"pos\00" -@fld.str.477 = private constant [5 x i8] c"file\00" -@field_names.478 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 3 }, { ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 4 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [4 x i8] c"src\00" -@fld.str.485 = private constant [4 x i8] c"pos\00" -@fld.str.486 = private constant [6 x i8] c"alloc\00" -@field_names.487 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 5 }] -@str.488 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.489 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.490 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.492 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.493 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.494 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.495 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.496 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.497 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.498 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.499 = private constant [5 x i8] c"name\00" -@fld.str.500 = private constant [12 x i8] c"takes_value\00" -@fld.str.501 = private constant [9 x i8] c"required\00" -@field_names.502 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.499, i64 4 }, { ptr, i64 } { ptr @fld.str.500, i64 11 }, { ptr, i64 } { ptr @fld.str.501, i64 8 }] -@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.504 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.505 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.507 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.508 = private constant [6 x i8] c"group\00" -@fld.str.509 = private constant [8 x i8] c"command\00" -@fld.str.510 = private constant [6 x i8] c"flags\00" -@field_names.511 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.508, i64 5 }, { ptr, i64 } { ptr @fld.str.509, i64 7 }, { ptr, i64 } { ptr @fld.str.510, i64 5 }] -@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.513 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.514 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.515 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.516 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.517 = private constant [4 x i8] c"set\00" -@fld.str.518 = private constant [6 x i8] c"value\00" -@field_names.519 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.517, i64 3 }, { ptr, i64 } { ptr @fld.str.518, i64 5 }] -@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.521 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.522 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.523 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.524 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.525 = private constant [6 x i8] c"index\00" -@fld.str.526 = private constant [6 x i8] c"token\00" -@field_names.527 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 5 }, { ptr, i64 } { ptr @fld.str.526, i64 5 }] -@str.528 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.529 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.530 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.532 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.533 = private constant [6 x i8] c"group\00" -@fld.str.534 = private constant [8 x i8] c"command\00" -@fld.str.535 = private constant [10 x i8] c"cmd_index\00" -@fld.str.536 = private constant [5 x i8] c"json\00" -@fld.str.537 = private constant [5 x i8] c"rest\00" -@fld.str.538 = private constant [5 x i8] c"spec\00" -@fld.str.539 = private constant [7 x i8] c"values\00" -@field_names.540 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.533, i64 5 }, { ptr, i64 } { ptr @fld.str.534, i64 7 }, { ptr, i64 } { ptr @fld.str.535, i64 9 }, { ptr, i64 } { ptr @fld.str.536, i64 4 }, { ptr, i64 } { ptr @fld.str.537, i64 4 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 6 }] -@str.541 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.542 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.543 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.544 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.545 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.546 = private constant [2 x i8] c"h\00" -@fld.str.547 = private constant [4 x i8] c"buf\00" -@fld.str.548 = private constant [8 x i8] c"buf_len\00" -@fld.str.549 = private constant [10 x i8] c"total_len\00" -@field_names.550 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.546, i64 1 }, { ptr, i64 } { ptr @fld.str.547, i64 3 }, { ptr, i64 } { ptr @fld.str.548, i64 7 }, { ptr, i64 } { ptr @fld.str.549, i64 9 }] -@str.551 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"S\00", align 1 -@str.553 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.555 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.556 = private constant [2 x i8] c"a\00" -@fld.str.557 = private constant [2 x i8] c"b\00" -@fld.str.558 = private constant [2 x i8] c"c\00" -@field_names.559 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 1 }, { ptr, i64 } { ptr @fld.str.557, i64 1 }, { ptr, i64 } { ptr @fld.str.558, i64 1 }] -@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.562 = private constant [5 x i8] c"read\00" -@fld.str.563 = private constant [6 x i8] c"write\00" -@fld.str.564 = private constant [7 x i8] c"append\00" -@fld.str.565 = private constant [11 x i8] c"read_write\00" -@field_names.566 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 4 }, { ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 6 }, { ptr, i64 } { ptr @fld.str.565, i64 10 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [4 x i8] c"set\00" -@fld.str.571 = private constant [8 x i8] c"current\00" -@fld.str.572 = private constant [4 x i8] c"end\00" -@field_names.573 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 7 }, { ptr, i64 } { ptr @fld.str.572, i64 3 }] -@str.574 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.575 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.577 = private constant [6 x i8] c"null_\00" -@fld.str.578 = private constant [6 x i8] c"bool_\00" -@fld.str.579 = private constant [5 x i8] c"int_\00" -@fld.str.580 = private constant [4 x i8] c"str\00" -@fld.str.581 = private constant [6 x i8] c"array\00" -@fld.str.582 = private constant [7 x i8] c"object\00" -@field_names.583 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 3 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 6 }] -@str.584 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.585 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.586 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.587 = private constant [6 x i8] c"macos\00" -@fld.str.588 = private constant [6 x i8] c"linux\00" -@fld.str.589 = private constant [8 x i8] c"windows\00" -@fld.str.590 = private constant [5 x i8] c"wasm\00" -@fld.str.591 = private constant [4 x i8] c"ios\00" -@fld.str.592 = private constant [8 x i8] c"android\00" -@fld.str.593 = private constant [8 x i8] c"unknown\00" -@field_names.594 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 5 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 4 }, { ptr, i64 } { ptr @fld.str.591, i64 3 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }] -@str.595 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.598 = private constant [8 x i8] c"aarch64\00" -@fld.str.599 = private constant [7 x i8] c"x86_64\00" -@fld.str.600 = private constant [7 x i8] c"wasm32\00" -@fld.str.601 = private constant [7 x i8] c"wasm64\00" -@fld.str.602 = private constant [8 x i8] c"unknown\00" -@field_names.603 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.598, i64 7 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 6 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 7 }] -@str.604 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.633 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.634 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.635 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.638 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.640 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.643 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.649 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.652 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.655 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.658 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.661 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.664 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.673 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.679 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.682 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.685 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.688 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.691 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.694 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.700 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.703 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.706 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.709 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [3 x i8] c"*S\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.340 = private constant [5 x i8] c"line\00" +@fld.str.341 = private constant [4 x i8] c"col\00" +@fld.str.342 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.340, i64 4 }, { ptr, i64 } { ptr @fld.str.341, i64 3 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }] +@str.343 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.344 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.345 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.346 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.348 = private constant [4 x i8] c"ctx\00" +@fld.str.349 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.350 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.351 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.348, i64 3 }, { ptr, i64 } { ptr @fld.str.349, i64 11 }, { ptr, i64 } { ptr @fld.str.350, i64 13 }] +@str.352 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.353 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.354 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.356 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.357 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.359 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.360 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.361 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.363 = private constant [12 x i8] c"alloc_count\00" +@field_names.364 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.363, i64 11 }] +@str.365 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.366 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.367 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.368 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.369 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.370 = private constant [5 x i8] c"next\00" +@fld.str.371 = private constant [4 x i8] c"cap\00" +@field_names.372 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.370, i64 4 }, { ptr, i64 } { ptr @fld.str.371, i64 3 }] +@str.373 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.374 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.375 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.377 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.378 = private constant [6 x i8] c"first\00" +@fld.str.379 = private constant [10 x i8] c"end_index\00" +@fld.str.380 = private constant [7 x i8] c"parent\00" +@field_names.381 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.378, i64 5 }, { ptr, i64 } { ptr @fld.str.379, i64 9 }, { ptr, i64 } { ptr @fld.str.380, i64 6 }] +@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.383 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.387 = private constant [4 x i8] c"buf\00" +@fld.str.388 = private constant [4 x i8] c"len\00" +@fld.str.389 = private constant [4 x i8] c"pos\00" +@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }] +@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.392 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.396 = private constant [7 x i8] c"parent\00" +@fld.str.397 = private constant [12 x i8] c"alloc_count\00" +@fld.str.398 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.399 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.400 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 6 }, { ptr, i64 } { ptr @fld.str.397, i64 11 }, { ptr, i64 } { ptr @fld.str.398, i64 13 }, { ptr, i64 } { ptr @fld.str.399, i64 17 }] +@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.402 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.403 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.404 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.405 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.406 = private constant [10 x i8] c"allocator\00" +@fld.str.407 = private constant [5 x i8] c"data\00" +@field_names.408 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 9 }, { ptr, i64 } { ptr @fld.str.407, i64 4 }] +@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.410 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.414 = private constant [3 x i8] c"fd\00" +@field_names.415 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 2 }] +@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.417 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.421 = private constant [5 x i8] c"file\00" +@fld.str.422 = private constant [5 x i8] c"line\00" +@fld.str.423 = private constant [4 x i8] c"col\00" +@fld.str.424 = private constant [5 x i8] c"func\00" +@fld.str.425 = private constant [10 x i8] c"line_text\00" +@field_names.426 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 9 }] +@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.428 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.432 = private constant [10 x i8] c"exit_code\00" +@fld.str.433 = private constant [7 x i8] c"stdout\00" +@field_names.434 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 9 }, { ptr, i64 } { ptr @fld.str.433, i64 6 }] +@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.436 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.437 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.438 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.439 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.440 = private constant [8 x i8] c"sin_len\00" +@fld.str.441 = private constant [11 x i8] c"sin_family\00" +@fld.str.442 = private constant [9 x i8] c"sin_port\00" +@fld.str.443 = private constant [9 x i8] c"sin_addr\00" +@fld.str.444 = private constant [9 x i8] c"sin_zero\00" +@field_names.445 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 7 }, { ptr, i64 } { ptr @fld.str.441, i64 10 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.448 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.449 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.450 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.451 = private constant [6 x i8] c"items\00" +@fld.str.452 = private constant [4 x i8] c"len\00" +@fld.str.453 = private constant [4 x i8] c"cap\00" +@field_names.454 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 5 }, { ptr, i64 } { ptr @fld.str.452, i64 3 }, { ptr, i64 } { ptr @fld.str.453, i64 3 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.460 = private constant [6 x i8] c"items\00" +@fld.str.461 = private constant [4 x i8] c"len\00" +@fld.str.462 = private constant [4 x i8] c"cap\00" +@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.469 = private constant [4 x i8] c"key\00" +@fld.str.470 = private constant [4 x i8] c"val\00" +@field_names.471 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }] +@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.473 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.477 = private constant [4 x i8] c"dst\00" +@fld.str.478 = private constant [4 x i8] c"pos\00" +@fld.str.479 = private constant [5 x i8] c"file\00" +@field_names.480 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 4 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [4 x i8] c"src\00" +@fld.str.487 = private constant [4 x i8] c"pos\00" +@fld.str.488 = private constant [6 x i8] c"alloc\00" +@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 5 }] +@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.491 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.495 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.497 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.501 = private constant [5 x i8] c"name\00" +@fld.str.502 = private constant [12 x i8] c"takes_value\00" +@fld.str.503 = private constant [9 x i8] c"required\00" +@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 4 }, { ptr, i64 } { ptr @fld.str.502, i64 11 }, { ptr, i64 } { ptr @fld.str.503, i64 8 }] +@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.506 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.510 = private constant [6 x i8] c"group\00" +@fld.str.511 = private constant [8 x i8] c"command\00" +@fld.str.512 = private constant [6 x i8] c"flags\00" +@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 5 }, { ptr, i64 } { ptr @fld.str.511, i64 7 }, { ptr, i64 } { ptr @fld.str.512, i64 5 }] +@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.515 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.519 = private constant [4 x i8] c"set\00" +@fld.str.520 = private constant [6 x i8] c"value\00" +@field_names.521 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 3 }, { ptr, i64 } { ptr @fld.str.520, i64 5 }] +@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.523 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.524 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.525 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.526 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.527 = private constant [6 x i8] c"index\00" +@fld.str.528 = private constant [6 x i8] c"token\00" +@field_names.529 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 5 }, { ptr, i64 } { ptr @fld.str.528, i64 5 }] +@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.531 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.532 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.534 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.535 = private constant [6 x i8] c"group\00" +@fld.str.536 = private constant [8 x i8] c"command\00" +@fld.str.537 = private constant [10 x i8] c"cmd_index\00" +@fld.str.538 = private constant [5 x i8] c"json\00" +@fld.str.539 = private constant [5 x i8] c"rest\00" +@fld.str.540 = private constant [5 x i8] c"spec\00" +@fld.str.541 = private constant [7 x i8] c"values\00" +@field_names.542 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 5 }, { ptr, i64 } { ptr @fld.str.536, i64 7 }, { ptr, i64 } { ptr @fld.str.537, i64 9 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 6 }] +@str.543 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.544 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.545 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.546 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.547 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.548 = private constant [2 x i8] c"h\00" +@fld.str.549 = private constant [4 x i8] c"buf\00" +@fld.str.550 = private constant [8 x i8] c"buf_len\00" +@fld.str.551 = private constant [10 x i8] c"total_len\00" +@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 1 }, { ptr, i64 } { ptr @fld.str.549, i64 3 }, { ptr, i64 } { ptr @fld.str.550, i64 7 }, { ptr, i64 } { ptr @fld.str.551, i64 9 }] +@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"S\00", align 1 +@str.555 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.557 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.558 = private constant [2 x i8] c"a\00" +@fld.str.559 = private constant [2 x i8] c"b\00" +@fld.str.560 = private constant [2 x i8] c"c\00" +@field_names.561 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 1 }, { ptr, i64 } { ptr @fld.str.559, i64 1 }, { ptr, i64 } { ptr @fld.str.560, i64 1 }] +@str.562 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.564 = private constant [5 x i8] c"read\00" +@fld.str.565 = private constant [6 x i8] c"write\00" +@fld.str.566 = private constant [7 x i8] c"append\00" +@fld.str.567 = private constant [11 x i8] c"read_write\00" +@field_names.568 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 4 }, { ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 6 }, { ptr, i64 } { ptr @fld.str.567, i64 10 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [4 x i8] c"set\00" +@fld.str.573 = private constant [8 x i8] c"current\00" +@fld.str.574 = private constant [4 x i8] c"end\00" +@field_names.575 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 3 }, { ptr, i64 } { ptr @fld.str.573, i64 7 }, { ptr, i64 } { ptr @fld.str.574, i64 3 }] +@str.576 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.577 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.579 = private constant [6 x i8] c"null_\00" +@fld.str.580 = private constant [6 x i8] c"bool_\00" +@fld.str.581 = private constant [5 x i8] c"int_\00" +@fld.str.582 = private constant [4 x i8] c"str\00" +@fld.str.583 = private constant [6 x i8] c"array\00" +@fld.str.584 = private constant [7 x i8] c"object\00" +@field_names.585 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 4 }, { ptr, i64 } { ptr @fld.str.582, i64 3 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 6 }] +@str.586 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.587 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.588 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.589 = private constant [6 x i8] c"macos\00" +@fld.str.590 = private constant [6 x i8] c"linux\00" +@fld.str.591 = private constant [8 x i8] c"windows\00" +@fld.str.592 = private constant [5 x i8] c"wasm\00" +@fld.str.593 = private constant [4 x i8] c"ios\00" +@fld.str.594 = private constant [8 x i8] c"android\00" +@fld.str.595 = private constant [8 x i8] c"unknown\00" +@field_names.596 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 5 }, { ptr, i64 } { ptr @fld.str.590, i64 5 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 3 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] +@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.600 = private constant [8 x i8] c"aarch64\00" +@fld.str.601 = private constant [7 x i8] c"x86_64\00" +@fld.str.602 = private constant [7 x i8] c"wasm32\00" +@fld.str.603 = private constant [7 x i8] c"wasm64\00" +@fld.str.604 = private constant [8 x i8] c"unknown\00" +@field_names.605 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.600, i64 7 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 6 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 7 }] +@str.606 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.634 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.635 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.636 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.637 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.640 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.642 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.645 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.651 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.654 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.657 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.660 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.663 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.666 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.675 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.681 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.684 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.687 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.690 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.693 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.696 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.702 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.705 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.708 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.711 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [3 x i8] c"*S\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -633,6 +633,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -852,7 +855,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -979,7 +982,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.78 ], [ { ptr @str.127, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1313,7 +1316,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1463,7 +1466,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1489,9 +1492,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1533,9 +1536,9 @@ entry: i64 85, label %match.arm.48 i64 100, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1577,7 +1580,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1621,9 +1624,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1705,9 +1708,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.340 [ i64 18, label %dispatch.case.341 - i64 21, label %dispatch.case.342 - i64 23, label %dispatch.case.343 - i64 25, label %dispatch.case.344 + i64 22, label %dispatch.case.342 + i64 24, label %dispatch.case.343 + i64 26, label %dispatch.case.344 i64 28, label %dispatch.case.345 i64 29, label %dispatch.case.346 i64 31, label %dispatch.case.347 @@ -1807,7 +1810,7 @@ dispatch.merge.94: ; preds = %dispatch.case.121, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1821,32 +1824,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2024,7 +2027,7 @@ dispatch.merge.252: ; preds = %dispatch.case.258, br label %match.merge.37 dispatch.default.253: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.252 dispatch.case.254: ; preds = %match.arm.44 @@ -2065,7 +2068,7 @@ dispatch.merge.269: ; preds = %dispatch.case.276, br label %match.merge.37 dispatch.default.270: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.269 dispatch.case.271: ; preds = %match.arm.47 @@ -2122,7 +2125,7 @@ dispatch.merge.307: ; preds = %dispatch.case.313, br label %match.merge.37 dispatch.default.308: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2171,7 +2174,7 @@ dispatch.merge.339: ; preds = %dispatch.case.371, br label %match.merge.37 dispatch.default.340: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2397,7 +2400,7 @@ dispatch.merge.478: ; preds = %dispatch.case.485, br label %match.merge.37 dispatch.default.479: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2455,7 +2458,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.315, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2551,7 +2554,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2559,7 +2562,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2569,13 +2572,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2583,7 +2586,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2597,7 +2600,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2605,7 +2608,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2616,7 +2619,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2673,7 +2676,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2681,7 +2684,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2692,7 +2695,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2712,7 +2715,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2720,7 +2723,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, 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 @@ -2731,7 +2734,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2741,64 +2744,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2974,163 +2980,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3328,64 +3337,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3415,97 +3424,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3544,13 +3553,13 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { entry: %alloca = alloca { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, align 8 - store { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } { { i64, i1 } { i64 42, i1 true }, { { ptr, i64 }, i1 } { { ptr, i64 } { ptr @str.330, i64 2 }, i1 true }, { i1, i1 } { i1 true, i1 true } }, ptr %alloca, align 8 + store { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } { { i64, i1 } { i64 42, i1 true }, { { ptr, i64 }, i1 } { { ptr, i64 } { ptr @str.332, i64 2 }, i1 true }, { i1, i1 } { i1 true, i1 true } }, ptr %alloca, align 8 %load = load { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, ptr %alloca, align 8 call void @print__ct_sbc6305862a3a863d__pack_S(ptr @__sx_default_context, { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } %load) %allocaN = alloca { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, align 8 @@ -3578,7 +3587,7 @@ entry: define internal void @print__ct_sbc6305862a3a863d__pack_S(ptr %0, { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.331, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.333, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, align 8 store { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } %1, ptr %allocaN, align 8 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3596,7 +3605,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, ptr %allocaN, align 8 %ba.tmp9 = alloca { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, align 8 @@ -3621,7 +3630,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.333, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.335, i64 3 }) ret { ptr, i64 } %call } @@ -3632,7 +3641,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.334, i64 15 }, { ptr, i64 } { ptr @str.335, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.336, i64 15 }, { ptr, i64 } { ptr @str.337, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3651,12 +3660,12 @@ while.body.123: ; preds = %while.hdr.122 while.exit.124: ; preds = %while.hdr.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 1 }) ret { ptr, i64 } %callN if.then.125: ; preds = %while.body.123 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.126 @@ -3668,7 +3677,7 @@ if.merge.126: ; preds = %if.then.125, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3721,20 +3730,20 @@ fv.case24: ; preds = %if.merge.126 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.342, i64 10 }, { ptr, i64 } { ptr @str.343, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.344, i64 9 }, { ptr, i64 } { ptr @str.345, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.127 -while.hdr.127: ; preds = %if.merge.131, %entry +while.hdr.127: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.128, label %while.exit.129 while.body.128: ; preds = %while.hdr.127 @@ -3744,224 +3753,24 @@ while.body.128: ; preds = %while.hdr.127 while.exit.129: ; preds = %while.hdr.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 1 }) ret { ptr, i64 } %callN if.then.130: ; preds = %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.131 if.merge.131: ; preds = %if.then.130, %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.346, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.351, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.127 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.348, i64 3 }, { ptr, i64 } { ptr @str.349, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.132 - -while.hdr.132: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.133, label %while.exit.134 - -while.body.133: ; preds = %while.hdr.132 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.135, label %if.merge.136 - -while.exit.134: ; preds = %while.hdr.132 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 1 }) - ret { ptr, i64 } %callN - -if.then.135: ; preds = %while.body.133 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.136 - -if.merge.136: ; preds = %if.then.135, %while.body.133 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.353, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.132 - -fv.default: ; preds = %if.merge.136 - br label %fv.merge - -fv.case: ; preds = %if.merge.136 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 10 }, { ptr, i64 } { ptr @str.356, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.137 - -while.hdr.137: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.138, label %while.exit.139 - -while.body.138: ; preds = %while.hdr.137 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.140, label %if.merge.141 - -while.exit.139: ; preds = %while.hdr.137 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) - ret { ptr, i64 } %callN - -if.then.140: ; preds = %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.141 - -if.merge.141: ; preds = %if.then.140, %while.body.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.361, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 - -fv.default: ; preds = %if.merge.141 - br label %fv.merge - -fv.case: ; preds = %if.merge.141 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.141 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.363, i64 9 }, { ptr, i64 } { ptr @str.364, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 - -while.hdr.142: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.143, label %while.exit.144 - -while.body.143: ; preds = %while.hdr.142 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 - -while.exit.144: ; preds = %while.hdr.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 1 }) - ret { ptr, i64 } %callN - -if.then.145: ; preds = %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 - -if.merge.146: ; preds = %if.then.145, %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.370, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, 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 @@ -3980,27 +3789,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.127 + +fv.default: ; preds = %if.merge.131 + br label %fv.merge + +fv.case: ; preds = %if.merge.131 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.131 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.131 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.353, i64 10 }, { ptr, i64 } { ptr @str.354, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.132 + +while.hdr.132: ; preds = %if.merge.136, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.133, label %while.exit.134 + +while.body.133: ; preds = %while.hdr.132 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.135, label %if.merge.136 + +while.exit.134: ; preds = %while.hdr.132 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 1 }) + ret { ptr, i64 } %callN + +if.then.135: ; preds = %while.body.133 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.136 + +if.merge.136: ; preds = %if.then.135, %while.body.133 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.357, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.132 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.359, i64 3 }, { ptr, i64 } { ptr @str.360, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.137 + +while.hdr.137: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.138, label %while.exit.139 + +while.body.138: ; preds = %while.hdr.137 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.140, label %if.merge.141 + +while.exit.139: ; preds = %while.hdr.137 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 1 }) + ret { ptr, i64 } %callN + +if.then.140: ; preds = %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.141 + +if.merge.141: ; preds = %if.then.140, %while.body.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.364, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 + +fv.default: ; preds = %if.merge.141 + br label %fv.merge + +fv.case: ; preds = %if.merge.141 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.366, i64 10 }, { ptr, i64 } { ptr @str.367, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.142 + +while.hdr.142: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.143, label %while.exit.144 + +while.body.143: ; preds = %while.hdr.142 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.145, label %if.merge.146 + +while.exit.144: ; preds = %while.hdr.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 1 }) + ret { ptr, i64 } %callN + +if.then.145: ; preds = %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.146 + +if.merge.146: ; preds = %if.then.145, %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.372, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.142 fv.default: ; preds = %if.merge.146 br label %fv.merge fv.case: ; preds = %if.merge.146 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.146 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.146 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4010,7 +4019,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.372, i64 5 }, { ptr, i64 } { ptr @str.373, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.374, i64 5 }, { ptr, i64 } { ptr @str.375, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4029,24 +4038,24 @@ while.body.148: ; preds = %while.hdr.147 while.exit.149: ; preds = %while.hdr.147 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 1 }) ret { ptr, i64 } %callN if.then.150: ; preds = %while.body.148 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.151 if.merge.151: ; preds = %if.then.150, %while.body.148 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.379, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.381, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, 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 @@ -4073,7 +4082,7 @@ fv.default: ; preds = %if.merge.151 fv.case: ; preds = %if.merge.151 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.151 @@ -4085,7 +4094,7 @@ fv.case20: ; preds = %if.merge.151 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4094,7 +4103,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 8 }, { ptr, i64 } { ptr @str.382, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 8 }, { ptr, i64 } { ptr @str.384, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4113,24 +4122,24 @@ while.body.153: ; preds = %while.hdr.152 while.exit.154: ; preds = %while.hdr.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) ret { ptr, i64 } %callN if.then.155: ; preds = %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.156 if.merge.156: ; preds = %if.then.155, %while.body.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.388, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.390, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, 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 @@ -4177,7 +4186,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 17 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 17 }, { ptr, i64 } { ptr @str.393, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4196,24 +4205,24 @@ while.body.158: ; preds = %while.hdr.157 while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) ret { ptr, i64 } %callN if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.161 if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.398, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.400, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4242,7 +4251,7 @@ fv.case: ; preds = %if.merge.161 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 @@ -4267,7 +4276,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 7 }, { ptr, i64 } { ptr @str.401, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 7 }, { ptr, i64 } { ptr @str.403, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4286,24 +4295,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %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.406, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.408, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, 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 @@ -4330,7 +4339,7 @@ fv.case: ; preds = %if.merge.166 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 @@ -4345,7 +4354,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.408, i64 4 }, { ptr, i64 } { ptr @str.409, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 4 }, { ptr, i64 } { ptr @str.411, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4364,24 +4373,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %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.413, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.415, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4418,7 +4427,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.415, i64 10 }, { ptr, i64 } { ptr @str.416, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 10 }, { ptr, i64 } { ptr @str.418, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4437,24 +4446,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.424, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4520,7 +4529,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 13 }, { ptr, i64 } { ptr @str.427, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 13 }, { ptr, i64 } { ptr @str.429, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4539,24 +4548,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %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.432, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.434, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4598,7 +4607,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.434, i64 8 }, { ptr, i64 } { ptr @str.435, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 8 }, { ptr, i64 } { ptr @str.437, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4617,24 +4626,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.443, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.445, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4695,7 +4704,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 5 }, { ptr, i64 } { ptr @str.446, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 5 }, { ptr, i64 } { ptr @str.448, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4714,24 +4723,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %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.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, 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 @@ -4777,7 +4786,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 6 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 6 }, { ptr, i64 } { ptr @str.457, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4796,24 +4805,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %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.461, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.463, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, 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 @@ -4861,7 +4870,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 6 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4880,24 +4889,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %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.469, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.471, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4941,7 +4950,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 4 }, { ptr, i64 } { ptr @str.472, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 4 }, { ptr, i64 } { ptr @str.474, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4960,24 +4969,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5027,7 +5036,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 6 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 6 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5046,24 +5055,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.487, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.489, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5103,7 +5112,7 @@ fv.case20: ; preds = %if.merge.211 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5112,7 +5121,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 12 }, { ptr, i64 } { ptr @str.490, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 12 }, { ptr, i64 } { ptr @str.492, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5131,24 +5140,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.493, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.495, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5168,7 +5177,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 8 }, { ptr, i64 } { ptr @str.496, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 8 }, { ptr, i64 } { ptr @str.498, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5187,24 +5196,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.502, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.504, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5256,7 +5265,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 7 }, { ptr, i64 } { ptr @str.505, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 7 }, { ptr, i64 } { ptr @str.507, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5275,24 +5284,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.511, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.513, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5344,7 +5353,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 9 }, { ptr, i64 } { ptr @str.514, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 9 }, { ptr, i64 } { ptr @str.516, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5363,24 +5372,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.519, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.521, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5423,7 +5432,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 4 }, { ptr, i64 } { ptr @str.522, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 4 }, { ptr, i64 } { ptr @str.524, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5442,24 +5451,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.527, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.529, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5505,7 +5514,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.529, i64 6 }, { ptr, i64 } { ptr @str.530, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 6 }, { ptr, i64 } { ptr @str.532, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5524,24 +5533,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.540, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.542, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5623,7 +5632,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.542, i64 6 }, { ptr, i64 } { ptr @str.543, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.544, i64 6 }, { ptr, i64 } { ptr @str.545, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5642,24 +5651,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.550, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5717,7 +5726,7 @@ entry: %ba.tmp19 = alloca { { ptr, i64 }, i1 }, align 8 %ba.tmp24 = alloca { i1, i1 }, align 8 store { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.552, i64 1 }, { ptr, i64 } { ptr @str.553, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 1 }, { ptr, i64 } { ptr @str.555, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5736,24 +5745,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %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.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, ptr %alloca, align 8 @@ -5808,9 +5817,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, 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 @@ -5829,8 +5838,8 @@ entry: if.then.259: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -5849,9 +5858,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, 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 @@ -5870,8 +5879,8 @@ entry: if.then.261: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.262 @@ -5901,9 +5910,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.585, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5920,8 +5929,8 @@ entry: if.then.263: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 @@ -5999,9 +6008,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, 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 @@ -6020,8 +6029,8 @@ entry: if.then.265: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.595, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -6040,9 +6049,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.605, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, 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 @@ -6061,8 +6070,8 @@ entry: if.then.267: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -6079,7 +6088,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.277 @@ -6096,12 +6105,12 @@ while.body.278: ; preds = %while.hdr.277 while.exit.279: ; preds = %while.hdr.277 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) ret { ptr, i64 } %call if.then.280: ; preds = %while.body.278 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.281 @@ -6130,7 +6139,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.282 @@ -6147,12 +6156,12 @@ while.body.283: ; preds = %while.hdr.282 while.exit.284: ; preds = %while.hdr.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) ret { ptr, i64 } %call if.then.285: ; preds = %while.body.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6182,7 +6191,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.287 @@ -6199,12 +6208,12 @@ while.body.288: ; preds = %while.hdr.287 while.exit.289: ; preds = %while.hdr.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) ret { ptr, i64 } %call if.then.290: ; preds = %while.body.288 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -6232,7 +6241,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.292 @@ -6249,12 +6258,12 @@ while.body.293: ; preds = %while.hdr.292 while.exit.294: ; preds = %while.hdr.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) ret { ptr, i64 } %call if.then.295: ; preds = %while.body.293 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -6283,7 +6292,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.297 @@ -6300,12 +6309,12 @@ while.body.298: ; preds = %while.hdr.297 while.exit.299: ; preds = %while.hdr.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) ret { ptr, i64 } %call if.then.300: ; preds = %while.body.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.301 @@ -6334,7 +6343,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.302 @@ -6351,12 +6360,12 @@ while.body.303: ; preds = %while.hdr.302 while.exit.304: ; preds = %while.hdr.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) ret { ptr, i64 } %call if.then.305: ; preds = %while.body.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.306 @@ -6386,7 +6395,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6405,12 +6414,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6439,7 +6448,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.319 @@ -6458,12 +6467,12 @@ while.body.320: ; preds = %while.hdr.319 while.exit.321: ; preds = %while.hdr.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) ret { ptr, i64 } %call if.then.322: ; preds = %while.body.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.323 @@ -6492,7 +6501,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.632, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.324 @@ -6511,12 +6520,12 @@ while.body.325: ; preds = %while.hdr.324 while.exit.326: ; preds = %while.hdr.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) ret { ptr, i64 } %call if.then.327: ; preds = %while.body.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.328 @@ -6546,7 +6555,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.633, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.635, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.329 @@ -6565,12 +6574,12 @@ while.body.330: ; preds = %while.hdr.329 while.exit.331: ; preds = %while.hdr.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 1 }) ret { ptr, i64 } %call if.then.332: ; preds = %while.body.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.333 @@ -6600,7 +6609,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.636, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.638, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.334 @@ -6619,12 +6628,12 @@ while.body.335: ; preds = %while.hdr.334 while.exit.336: ; preds = %while.hdr.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) ret { ptr, i64 } %call if.then.337: ; preds = %while.body.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.338 @@ -6666,12 +6675,12 @@ if.then.372: ; preds = %entry if.else.373: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 5 }, { ptr, i64 } %callN) br label %if.merge.374 if.merge.374: ; preds = %if.else.373, %if.then.372 - %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6694,12 +6703,12 @@ if.then.388: ; preds = %entry if.else.389: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 11 }, { ptr, i64 } %callN) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6722,12 +6731,12 @@ if.then.391: ; preds = %entry if.else.392: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 4 }, { ptr, i64 } %callN) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6750,12 +6759,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 11 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6778,12 +6787,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 6 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6805,12 +6814,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6833,12 +6842,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 9 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6861,12 +6870,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 18 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6889,12 +6898,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 5 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6917,12 +6926,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6945,12 +6954,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6973,12 +6982,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 9 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7001,12 +7010,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 4 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7028,12 +7037,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 8 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7056,12 +7065,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 6 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7083,12 +7092,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 9 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7111,12 +7120,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 7 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7139,12 +7148,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 5 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7167,12 +7176,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7195,12 +7204,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 4 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7223,12 +7232,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7251,12 +7260,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 5 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7279,12 +7288,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 7 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7307,12 +7316,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 12 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7335,12 +7344,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 6 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7363,12 +7372,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 2 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 2 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7391,12 +7400,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7419,12 +7428,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 4 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7447,12 +7456,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7475,12 +7484,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7503,12 +7512,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7524,7 +7533,7 @@ entry: br i1 %lnot, label %if.then.486, label %if.merge.487 if.then.486: ; preds = %entry - ret { ptr, i64 } { ptr @str.732, i64 4 } + ret { ptr, i64 } { ptr @str.734, i64 4 } if.merge.487: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7548,7 +7557,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.733, i64 4 } + ret { ptr, i64 } { ptr @str.735, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7572,7 +7581,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.734, i64 4 } + ret { ptr, i64 } { ptr @str.736, i64 4 } if.merge.491: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7596,7 +7605,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.735, i64 4 } + ret { ptr, i64 } { ptr @str.737, i64 4 } if.merge.493: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -7619,7 +7628,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.736, i64 4 } + ret { ptr, i64 } { ptr @str.738, i64 4 } if.merge.495: ; preds = %entry %loadN = load { i64, i1 }, ptr %alloca, align 8 @@ -7640,7 +7649,7 @@ entry: br i1 %lnot, label %if.then.496, label %if.merge.497 if.then.496: ; preds = %entry - ret { ptr, i64 } { ptr @str.737, i64 4 } + ret { ptr, i64 } { ptr @str.739, i64 4 } if.merge.497: ; preds = %entry %loadN = load { i1, i1 }, ptr %alloca, align 1 diff --git a/examples/expected/1004-errors-try.ir b/examples/expected/1004-errors-try.ir index e6b4900..bcae185 100644 --- a/examples/expected/1004-errors-try.ir +++ b/examples/expected/1004-errors-try.ir @@ -1,619 +1,619 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [162 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag.str.144 = private constant [4 x i8] c"Bad\00" -@tag.str.145 = private constant [6 x i8] c"Worse\00" -@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 3 }, { ptr, i64 } { ptr @tag.str.145, i64 5 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.146 = private constant [4 x i8] c"Bad\00" +@tag.str.147 = private constant [6 x i8] c"Worse\00" +@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 3 }, { ptr, i64 } { ptr @tag.str.147, i64 5 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.146 = private constant [5 x i8] c"bool\00" -@tn.str.147 = private constant [3 x i8] c"s8\00" -@tn.str.148 = private constant [4 x i8] c"s16\00" -@tn.str.149 = private constant [4 x i8] c"s32\00" -@tn.str.150 = private constant [4 x i8] c"s64\00" -@tn.str.151 = private constant [3 x i8] c"u8\00" -@tn.str.152 = private constant [4 x i8] c"u16\00" -@tn.str.153 = private constant [4 x i8] c"u32\00" -@tn.str.154 = private constant [4 x i8] c"u64\00" -@tn.str.155 = private constant [4 x i8] c"f32\00" -@tn.str.156 = private constant [4 x i8] c"f64\00" -@tn.str.157 = private constant [7 x i8] c"string\00" -@tn.str.158 = private constant [4 x i8] c"Any\00" -@tn.str.159 = private constant [9 x i8] c"noreturn\00" -@tn.str.160 = private constant [6 x i8] c"isize\00" -@tn.str.161 = private constant [6 x i8] c"usize\00" -@tn.str.162 = private constant [5 x i8] c"void\00" -@tn.str.163 = private constant [6 x i8] c"*void\00" -@tn.str.164 = private constant [16 x i8] c"Source_Location\00" -@tn.str.165 = private constant [11 x i8] c"CAllocator\00" -@tn.str.166 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.167 = private constant [4 x i8] c"GPA\00" -@tn.str.168 = private constant [5 x i8] c"*GPA\00" -@tn.str.169 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.170 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.171 = private constant [10 x i8] c"Allocator\00" -@tn.str.172 = private constant [6 x i8] c"Arena\00" -@tn.str.173 = private constant [7 x i8] c"*Arena\00" -@tn.str.174 = private constant [6 x i8] c"[*]u8\00" -@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.179 = private constant [8 x i8] c"Context\00" -@tn.str.180 = private constant [7 x i8] c"[4]s64\00" -@tn.str.181 = private constant [9 x i8] c"[]string\00" -@tn.str.182 = private constant [9 x i8] c"OpenMode\00" -@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.184 = private constant [5 x i8] c"File\00" -@tn.str.185 = private constant [6 x i8] c"*File\00" -@tn.str.186 = private constant [6 x i8] c"?File\00" -@tn.str.187 = private constant [8 x i8] c"?string\00" -@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.189 = private constant [4 x i8] c"*u8\00" -@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.192 = private constant [5 x i8] c"*s32\00" -@tn.str.193 = private constant [9 x i8] c"SockAddr\00" -@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.195 = private constant [5 x i8] c"*u32\00" -@tn.str.196 = private constant [10 x i8] c"JsonError\00" -@tn.str.197 = private constant [6 x i8] c"Array\00" -@tn.str.198 = private constant [7 x i8] c"Object\00" -@tn.str.199 = private constant [6 x i8] c"Value\00" -@tn.str.200 = private constant [7 x i8] c"Member\00" -@tn.str.201 = private constant [9 x i8] c"[*]Value\00" -@tn.str.202 = private constant [7 x i8] c"*Array\00" -@tn.str.203 = private constant [10 x i8] c"[*]Member\00" -@tn.str.204 = private constant [8 x i8] c"*Object\00" -@tn.str.205 = private constant [5 x i8] c"[]u8\00" -@tn.str.206 = private constant [5 x i8] c"Sink\00" -@tn.str.207 = private constant [6 x i8] c"*Sink\00" -@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.211 = private constant [7 x i8] c"Parser\00" -@tn.str.212 = private constant [8 x i8] c"*Parser\00" -@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.216 = private constant [13 x i8] c"Architecture\00" -@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.218 = private constant [11 x i8] c"() -> bool\00" -@tn.str.219 = private constant [5 x i8] c"*s64\00" -@tn.str.220 = private constant [9 x i8] c"CliError\00" -@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.223 = private constant [8 x i8] c"Command\00" -@tn.str.224 = private constant [10 x i8] c"FlagValue\00" -@tn.str.225 = private constant [5 x i8] c"Diag\00" -@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.227 = private constant [7 x i8] c"Parsed\00" -@tn.str.228 = private constant [8 x i8] c"*Parsed\00" -@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.230 = private constant [10 x i8] c"[]Command\00" -@tn.str.231 = private constant [6 x i8] c"*Diag\00" -@tn.str.232 = private constant [7 x i8] c"[8]s64\00" -@tn.str.233 = private constant [7 x i8] c"[64]u8\00" -@tn.str.234 = private constant [7 x i8] c"Sha256\00" -@tn.str.235 = private constant [8 x i8] c"*Sha256\00" -@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.237 = private constant [8 x i8] c"[64]s64\00" -@tn.str.238 = private constant [2 x i8] c"E\00" -@tn.str.239 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.240 = private constant [7 x i8] c"**void\00" -@tn.str.241 = private constant [3 x i8] c"*E\00" -@tn.str.242 = private constant [8 x i8] c"*string\00" -@tn.str.243 = private constant [6 x i8] c"[]Any\00" -@tn.str.244 = private constant [5 x i8] c"*Any\00" -@tn.str.245 = private constant [7 x i8] c"[1]Any\00" -@tn.str.246 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.247 = private constant [7 x i8] c"*[]Any\00" -@tn.str.248 = private constant [6 x i8] c"*bool\00" -@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.250 = private constant [5 x i8] c"*f64\00" -@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.252 = private constant [11 x i8] c"*Allocator\00" -@tn.str.253 = private constant [9 x i8] c"*Context\00" -@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.256 = private constant [8 x i8] c"*Member\00" -@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.259 = private constant [9 x i8] c"*Command\00" -@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.263 = private constant [7 x i8] c"*Value\00" -@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.265 = private constant [14 x i8] c"*Architecture\00" -@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.270 = private constant [10 x i8] c"*[]string\00" -@tn.str.271 = private constant [6 x i8] c"*[]u8\00" -@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.273 = private constant [11 x i8] c"*[]Command\00" -@tn.str.274 = private constant [6 x i8] c"**GPA\00" -@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.276 = private constant [8 x i8] c"**Arena\00" -@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.280 = private constant [7 x i8] c"**File\00" -@tn.str.281 = private constant [5 x i8] c"**u8\00" -@tn.str.282 = private constant [6 x i8] c"**s32\00" -@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.284 = private constant [6 x i8] c"**u32\00" -@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.286 = private constant [8 x i8] c"**Array\00" -@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.288 = private constant [9 x i8] c"**Object\00" -@tn.str.289 = private constant [7 x i8] c"**Sink\00" -@tn.str.290 = private constant [9 x i8] c"**Parser\00" -@tn.str.291 = private constant [6 x i8] c"**s64\00" -@tn.str.292 = private constant [9 x i8] c"**Parsed\00" -@tn.str.293 = private constant [7 x i8] c"**Diag\00" -@tn.str.294 = private constant [9 x i8] c"**Sha256\00" -@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.296 = private constant [8 x i8] c"***void\00" -@tn.str.297 = private constant [4 x i8] c"**E\00" -@tn.str.298 = private constant [9 x i8] c"**string\00" -@tn.str.299 = private constant [6 x i8] c"**Any\00" -@tn.str.300 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.301 = private constant [8 x i8] c"**[]Any\00" -@tn.str.302 = private constant [7 x i8] c"**bool\00" -@tn.str.303 = private constant [7 x i8] c"*?File\00" -@tn.str.304 = private constant [9 x i8] c"*?string\00" -@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 10 }, { ptr, i64 } { ptr @tn.str.166, i64 11 }, { ptr, i64 } { ptr @tn.str.167, i64 3 }, { ptr, i64 } { ptr @tn.str.168, i64 4 }, { ptr, i64 } { ptr @tn.str.169, i64 10 }, { ptr, i64 } { ptr @tn.str.170, i64 11 }, { ptr, i64 } { ptr @tn.str.171, i64 9 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 1 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 2 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 5 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 3 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 7 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }] -@str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.148 = private constant [5 x i8] c"bool\00" +@tn.str.149 = private constant [3 x i8] c"s8\00" +@tn.str.150 = private constant [4 x i8] c"s16\00" +@tn.str.151 = private constant [4 x i8] c"s32\00" +@tn.str.152 = private constant [4 x i8] c"s64\00" +@tn.str.153 = private constant [3 x i8] c"u8\00" +@tn.str.154 = private constant [4 x i8] c"u16\00" +@tn.str.155 = private constant [4 x i8] c"u32\00" +@tn.str.156 = private constant [4 x i8] c"u64\00" +@tn.str.157 = private constant [4 x i8] c"f32\00" +@tn.str.158 = private constant [4 x i8] c"f64\00" +@tn.str.159 = private constant [7 x i8] c"string\00" +@tn.str.160 = private constant [4 x i8] c"Any\00" +@tn.str.161 = private constant [9 x i8] c"noreturn\00" +@tn.str.162 = private constant [6 x i8] c"isize\00" +@tn.str.163 = private constant [6 x i8] c"usize\00" +@tn.str.164 = private constant [5 x i8] c"void\00" +@tn.str.165 = private constant [6 x i8] c"*void\00" +@tn.str.166 = private constant [16 x i8] c"Source_Location\00" +@tn.str.167 = private constant [10 x i8] c"Allocator\00" +@tn.str.168 = private constant [11 x i8] c"CAllocator\00" +@tn.str.169 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.170 = private constant [4 x i8] c"GPA\00" +@tn.str.171 = private constant [5 x i8] c"*GPA\00" +@tn.str.172 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.173 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.174 = private constant [6 x i8] c"Arena\00" +@tn.str.175 = private constant [7 x i8] c"*Arena\00" +@tn.str.176 = private constant [6 x i8] c"[*]u8\00" +@tn.str.177 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.178 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.179 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.180 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.181 = private constant [8 x i8] c"Context\00" +@tn.str.182 = private constant [7 x i8] c"[4]s64\00" +@tn.str.183 = private constant [9 x i8] c"[]string\00" +@tn.str.184 = private constant [9 x i8] c"OpenMode\00" +@tn.str.185 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.186 = private constant [5 x i8] c"File\00" +@tn.str.187 = private constant [6 x i8] c"*File\00" +@tn.str.188 = private constant [6 x i8] c"?File\00" +@tn.str.189 = private constant [8 x i8] c"?string\00" +@tn.str.190 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.191 = private constant [4 x i8] c"*u8\00" +@tn.str.192 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.193 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.194 = private constant [5 x i8] c"*s32\00" +@tn.str.195 = private constant [9 x i8] c"SockAddr\00" +@tn.str.196 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.197 = private constant [5 x i8] c"*u32\00" +@tn.str.198 = private constant [10 x i8] c"JsonError\00" +@tn.str.199 = private constant [6 x i8] c"Array\00" +@tn.str.200 = private constant [7 x i8] c"Object\00" +@tn.str.201 = private constant [6 x i8] c"Value\00" +@tn.str.202 = private constant [7 x i8] c"Member\00" +@tn.str.203 = private constant [9 x i8] c"[*]Value\00" +@tn.str.204 = private constant [7 x i8] c"*Array\00" +@tn.str.205 = private constant [10 x i8] c"[*]Member\00" +@tn.str.206 = private constant [8 x i8] c"*Object\00" +@tn.str.207 = private constant [5 x i8] c"[]u8\00" +@tn.str.208 = private constant [5 x i8] c"Sink\00" +@tn.str.209 = private constant [6 x i8] c"*Sink\00" +@tn.str.210 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.211 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.212 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.213 = private constant [7 x i8] c"Parser\00" +@tn.str.214 = private constant [8 x i8] c"*Parser\00" +@tn.str.215 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.216 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.217 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.218 = private constant [13 x i8] c"Architecture\00" +@tn.str.219 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.220 = private constant [11 x i8] c"() -> bool\00" +@tn.str.221 = private constant [5 x i8] c"*s64\00" +@tn.str.222 = private constant [9 x i8] c"CliError\00" +@tn.str.223 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.224 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.225 = private constant [8 x i8] c"Command\00" +@tn.str.226 = private constant [10 x i8] c"FlagValue\00" +@tn.str.227 = private constant [5 x i8] c"Diag\00" +@tn.str.228 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.229 = private constant [7 x i8] c"Parsed\00" +@tn.str.230 = private constant [8 x i8] c"*Parsed\00" +@tn.str.231 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.232 = private constant [10 x i8] c"[]Command\00" +@tn.str.233 = private constant [6 x i8] c"*Diag\00" +@tn.str.234 = private constant [7 x i8] c"[8]s64\00" +@tn.str.235 = private constant [7 x i8] c"[64]u8\00" +@tn.str.236 = private constant [7 x i8] c"Sha256\00" +@tn.str.237 = private constant [8 x i8] c"*Sha256\00" +@tn.str.238 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.239 = private constant [8 x i8] c"[64]s64\00" +@tn.str.240 = private constant [2 x i8] c"E\00" +@tn.str.241 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.242 = private constant [7 x i8] c"**void\00" +@tn.str.243 = private constant [3 x i8] c"*E\00" +@tn.str.244 = private constant [8 x i8] c"*string\00" +@tn.str.245 = private constant [6 x i8] c"[]Any\00" +@tn.str.246 = private constant [5 x i8] c"*Any\00" +@tn.str.247 = private constant [7 x i8] c"[1]Any\00" +@tn.str.248 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.249 = private constant [7 x i8] c"*[]Any\00" +@tn.str.250 = private constant [6 x i8] c"*bool\00" +@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.252 = private constant [5 x i8] c"*f64\00" +@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.254 = private constant [11 x i8] c"*Allocator\00" +@tn.str.255 = private constant [9 x i8] c"*Context\00" +@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.258 = private constant [8 x i8] c"*Member\00" +@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.261 = private constant [9 x i8] c"*Command\00" +@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.265 = private constant [7 x i8] c"*Value\00" +@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.267 = private constant [14 x i8] c"*Architecture\00" +@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.272 = private constant [10 x i8] c"*[]string\00" +@tn.str.273 = private constant [6 x i8] c"*[]u8\00" +@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.275 = private constant [11 x i8] c"*[]Command\00" +@tn.str.276 = private constant [6 x i8] c"**GPA\00" +@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.278 = private constant [8 x i8] c"**Arena\00" +@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.282 = private constant [7 x i8] c"**File\00" +@tn.str.283 = private constant [5 x i8] c"**u8\00" +@tn.str.284 = private constant [6 x i8] c"**s32\00" +@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.286 = private constant [6 x i8] c"**u32\00" +@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.288 = private constant [8 x i8] c"**Array\00" +@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.290 = private constant [9 x i8] c"**Object\00" +@tn.str.291 = private constant [7 x i8] c"**Sink\00" +@tn.str.292 = private constant [9 x i8] c"**Parser\00" +@tn.str.293 = private constant [6 x i8] c"**s64\00" +@tn.str.294 = private constant [9 x i8] c"**Parsed\00" +@tn.str.295 = private constant [7 x i8] c"**Diag\00" +@tn.str.296 = private constant [9 x i8] c"**Sha256\00" +@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.298 = private constant [8 x i8] c"***void\00" +@tn.str.299 = private constant [4 x i8] c"**E\00" +@tn.str.300 = private constant [9 x i8] c"**string\00" +@tn.str.301 = private constant [6 x i8] c"**Any\00" +@tn.str.302 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.303 = private constant [8 x i8] c"**[]Any\00" +@tn.str.304 = private constant [7 x i8] c"**bool\00" +@tn.str.305 = private constant [7 x i8] c"*?File\00" +@tn.str.306 = private constant [9 x i8] c"*?string\00" +@tn.str.307 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.308 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.148, i64 4 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 2 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 3 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 6 }, { ptr, i64 } { ptr @tn.str.160, i64 3 }, { ptr, i64 } { ptr @tn.str.161, i64 8 }, { ptr, i64 } { ptr @tn.str.162, i64 5 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 4 }, { ptr, i64 } { ptr @tn.str.165, i64 5 }, { ptr, i64 } { ptr @tn.str.166, i64 15 }, { ptr, i64 } { ptr @tn.str.167, i64 9 }, { ptr, i64 } { ptr @tn.str.168, i64 10 }, { ptr, i64 } { ptr @tn.str.169, i64 11 }, { ptr, i64 } { ptr @tn.str.170, i64 3 }, { ptr, i64 } { ptr @tn.str.171, i64 4 }, { ptr, i64 } { ptr @tn.str.172, i64 10 }, { ptr, i64 } { ptr @tn.str.173, i64 11 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 6 }, { ptr, i64 } { ptr @tn.str.176, i64 5 }, { ptr, i64 } { ptr @tn.str.177, i64 8 }, { ptr, i64 } { ptr @tn.str.178, i64 9 }, { ptr, i64 } { ptr @tn.str.179, i64 17 }, { ptr, i64 } { ptr @tn.str.180, i64 18 }, { ptr, i64 } { ptr @tn.str.181, i64 7 }, { ptr, i64 } { ptr @tn.str.182, i64 6 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 8 }, { ptr, i64 } { ptr @tn.str.185, i64 8 }, { ptr, i64 } { ptr @tn.str.186, i64 4 }, { ptr, i64 } { ptr @tn.str.187, i64 5 }, { ptr, i64 } { ptr @tn.str.188, i64 5 }, { ptr, i64 } { ptr @tn.str.189, i64 7 }, { ptr, i64 } { ptr @tn.str.190, i64 10 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 13 }, { ptr, i64 } { ptr @tn.str.193, i64 14 }, { ptr, i64 } { ptr @tn.str.194, i64 4 }, { ptr, i64 } { ptr @tn.str.195, i64 8 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 4 }, { ptr, i64 } { ptr @tn.str.198, i64 9 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 5 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 8 }, { ptr, i64 } { ptr @tn.str.204, i64 6 }, { ptr, i64 } { ptr @tn.str.205, i64 9 }, { ptr, i64 } { ptr @tn.str.206, i64 7 }, { ptr, i64 } { ptr @tn.str.207, i64 4 }, { ptr, i64 } { ptr @tn.str.208, i64 4 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 16 }, { ptr, i64 } { ptr @tn.str.211, i64 14 }, { ptr, i64 } { ptr @tn.str.212, i64 21 }, { ptr, i64 } { ptr @tn.str.213, i64 6 }, { ptr, i64 } { ptr @tn.str.214, i64 7 }, { ptr, i64 } { ptr @tn.str.215, i64 24 }, { ptr, i64 } { ptr @tn.str.216, i64 23 }, { ptr, i64 } { ptr @tn.str.217, i64 15 }, { ptr, i64 } { ptr @tn.str.218, i64 12 }, { ptr, i64 } { ptr @tn.str.219, i64 12 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 4 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 8 }, { ptr, i64 } { ptr @tn.str.224, i64 10 }, { ptr, i64 } { ptr @tn.str.225, i64 7 }, { ptr, i64 } { ptr @tn.str.226, i64 9 }, { ptr, i64 } { ptr @tn.str.227, i64 4 }, { ptr, i64 } { ptr @tn.str.228, i64 13 }, { ptr, i64 } { ptr @tn.str.229, i64 6 }, { ptr, i64 } { ptr @tn.str.230, i64 7 }, { ptr, i64 } { ptr @tn.str.231, i64 18 }, { ptr, i64 } { ptr @tn.str.232, i64 9 }, { ptr, i64 } { ptr @tn.str.233, i64 5 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 6 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 1 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 2 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 3 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 15 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }] @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.313 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.314 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.315 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.316 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.317 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.318 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.315 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.316 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.317 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.318 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.319 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.320 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.324 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.325 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.326 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.327 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.328 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.329 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @frame.str = private unnamed_addr constant [19 x i8] c"1004-errors-try.sx\00" -@frame.str.328 = private unnamed_addr constant [6 x i8] c"inner\00" -@frame.str.329 = private unnamed_addr constant [34 x i8] c" if n < 0 { raise error.Bad; }\00" -@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 18 }, i32 13, i32 16, { ptr, i64 } { ptr @frame.str.328, i64 5 }, { ptr, i64 } { ptr @frame.str.329, i64 33 } } -@frame.str.330 = private unnamed_addr constant [6 x i8] c"outer\00" -@frame.str.331 = private unnamed_addr constant [18 x i8] c" try inner(n);\00" -@trace.frame.332 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 18 }, i32 19, i32 5, { ptr, i64 } { ptr @frame.str.330, i64 5 }, { ptr, i64 } { ptr @frame.str.331, i64 17 } } -@str.333 = private unnamed_addr constant [16 x i8] c"try result: {}\0A\00", align 1 -@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@frame.str.330 = private unnamed_addr constant [6 x i8] c"inner\00" +@frame.str.331 = private unnamed_addr constant [34 x i8] c" if n < 0 { raise error.Bad; }\00" +@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 18 }, i32 13, i32 16, { ptr, i64 } { ptr @frame.str.330, i64 5 }, { ptr, i64 } { ptr @frame.str.331, i64 33 } } +@frame.str.332 = private unnamed_addr constant [6 x i8] c"outer\00" +@frame.str.333 = private unnamed_addr constant [18 x i8] c" try inner(n);\00" +@trace.frame.334 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 18 }, i32 19, i32 5, { ptr, i64 } { ptr @frame.str.332, i64 5 }, { ptr, i64 } { ptr @frame.str.333, i64 17 } } @str.335 = private unnamed_addr constant [16 x i8] c"try result: {}\0A\00", align 1 -@str.336 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.337 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.338 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.339 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.337 = private unnamed_addr constant [16 x i8] c"try result: {}\0A\00", align 1 +@str.338 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.339 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.340 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.340 = private constant [5 x i8] c"line\00" -@fld.str.341 = private constant [4 x i8] c"col\00" -@fld.str.342 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.340, i64 4 }, { ptr, i64 } { ptr @fld.str.341, i64 3 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }] -@str.343 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.344 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.346 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.347 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.348 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.350 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.351 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.353 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.354 = private constant [12 x i8] c"alloc_count\00" -@field_names.355 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 11 }] -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.361 = private constant [5 x i8] c"next\00" -@fld.str.362 = private constant [4 x i8] c"cap\00" -@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 4 }, { ptr, i64 } { ptr @fld.str.362, i64 3 }] -@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.365 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.367 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.369 = private constant [4 x i8] c"ctx\00" -@fld.str.370 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.371 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.372 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.369, i64 3 }, { ptr, i64 } { ptr @fld.str.370, i64 11 }, { ptr, i64 } { ptr @fld.str.371, i64 13 }] -@str.373 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.374 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.375 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.376 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.377 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.378 = private constant [6 x i8] c"first\00" -@fld.str.379 = private constant [10 x i8] c"end_index\00" -@fld.str.380 = private constant [7 x i8] c"parent\00" -@field_names.381 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.378, i64 5 }, { ptr, i64 } { ptr @fld.str.379, i64 9 }, { ptr, i64 } { ptr @fld.str.380, i64 6 }] -@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.383 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.387 = private constant [4 x i8] c"buf\00" -@fld.str.388 = private constant [4 x i8] c"len\00" -@fld.str.389 = private constant [4 x i8] c"pos\00" -@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 3 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }] -@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.392 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.396 = private constant [7 x i8] c"parent\00" -@fld.str.397 = private constant [12 x i8] c"alloc_count\00" -@fld.str.398 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.399 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.400 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 6 }, { ptr, i64 } { ptr @fld.str.397, i64 11 }, { ptr, i64 } { ptr @fld.str.398, i64 13 }, { ptr, i64 } { ptr @fld.str.399, i64 17 }] -@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.402 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.404 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.405 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.406 = private constant [10 x i8] c"allocator\00" -@fld.str.407 = private constant [5 x i8] c"data\00" -@field_names.408 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 9 }, { ptr, i64 } { ptr @fld.str.407, i64 4 }] -@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.410 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.413 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.414 = private constant [3 x i8] c"fd\00" -@field_names.415 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 2 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [5 x i8] c"file\00" -@fld.str.422 = private constant [5 x i8] c"line\00" -@fld.str.423 = private constant [4 x i8] c"col\00" -@fld.str.424 = private constant [5 x i8] c"func\00" -@fld.str.425 = private constant [10 x i8] c"line_text\00" -@field_names.426 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 4 }, { ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 9 }] -@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.428 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.432 = private constant [10 x i8] c"exit_code\00" -@fld.str.433 = private constant [7 x i8] c"stdout\00" -@field_names.434 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 9 }, { ptr, i64 } { ptr @fld.str.433, i64 6 }] -@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.436 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.439 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.440 = private constant [8 x i8] c"sin_len\00" -@fld.str.441 = private constant [11 x i8] c"sin_family\00" -@fld.str.442 = private constant [9 x i8] c"sin_port\00" -@fld.str.443 = private constant [9 x i8] c"sin_addr\00" -@fld.str.444 = private constant [9 x i8] c"sin_zero\00" -@field_names.445 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 7 }, { ptr, i64 } { ptr @fld.str.441, i64 10 }, { ptr, i64 } { ptr @fld.str.442, i64 8 }, { ptr, i64 } { ptr @fld.str.443, i64 8 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }] -@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.447 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.449 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.450 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.451 = private constant [6 x i8] c"items\00" -@fld.str.452 = private constant [4 x i8] c"len\00" -@fld.str.453 = private constant [4 x i8] c"cap\00" -@field_names.454 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 5 }, { ptr, i64 } { ptr @fld.str.452, i64 3 }, { ptr, i64 } { ptr @fld.str.453, i64 3 }] -@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.456 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.460 = private constant [6 x i8] c"items\00" -@fld.str.461 = private constant [4 x i8] c"len\00" -@fld.str.462 = private constant [4 x i8] c"cap\00" -@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] -@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.465 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.469 = private constant [4 x i8] c"key\00" -@fld.str.470 = private constant [4 x i8] c"val\00" -@field_names.471 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }] -@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.473 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.477 = private constant [4 x i8] c"dst\00" -@fld.str.478 = private constant [4 x i8] c"pos\00" -@fld.str.479 = private constant [5 x i8] c"file\00" -@field_names.480 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 4 }] -@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.482 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.486 = private constant [4 x i8] c"src\00" -@fld.str.487 = private constant [4 x i8] c"pos\00" -@fld.str.488 = private constant [6 x i8] c"alloc\00" -@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 5 }] -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.495 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.497 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.498 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.500 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.501 = private constant [5 x i8] c"name\00" -@fld.str.502 = private constant [12 x i8] c"takes_value\00" -@fld.str.503 = private constant [9 x i8] c"required\00" -@field_names.504 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.501, i64 4 }, { ptr, i64 } { ptr @fld.str.502, i64 11 }, { ptr, i64 } { ptr @fld.str.503, i64 8 }] -@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.506 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.510 = private constant [6 x i8] c"group\00" -@fld.str.511 = private constant [8 x i8] c"command\00" -@fld.str.512 = private constant [6 x i8] c"flags\00" -@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 5 }, { ptr, i64 } { ptr @fld.str.511, i64 7 }, { ptr, i64 } { ptr @fld.str.512, i64 5 }] -@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.515 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.519 = private constant [4 x i8] c"set\00" -@fld.str.520 = private constant [6 x i8] c"value\00" -@field_names.521 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 3 }, { ptr, i64 } { ptr @fld.str.520, i64 5 }] -@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.523 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.525 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.526 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.527 = private constant [6 x i8] c"index\00" -@fld.str.528 = private constant [6 x i8] c"token\00" -@field_names.529 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 5 }, { ptr, i64 } { ptr @fld.str.528, i64 5 }] -@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.531 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.533 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.534 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.535 = private constant [6 x i8] c"group\00" -@fld.str.536 = private constant [8 x i8] c"command\00" -@fld.str.537 = private constant [10 x i8] c"cmd_index\00" -@fld.str.538 = private constant [5 x i8] c"json\00" -@fld.str.539 = private constant [5 x i8] c"rest\00" -@fld.str.540 = private constant [5 x i8] c"spec\00" -@fld.str.541 = private constant [7 x i8] c"values\00" -@field_names.542 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 5 }, { ptr, i64 } { ptr @fld.str.536, i64 7 }, { ptr, i64 } { ptr @fld.str.537, i64 9 }, { ptr, i64 } { ptr @fld.str.538, i64 4 }, { ptr, i64 } { ptr @fld.str.539, i64 4 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 6 }] -@str.543 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.544 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.545 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.547 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.548 = private constant [2 x i8] c"h\00" -@fld.str.549 = private constant [4 x i8] c"buf\00" -@fld.str.550 = private constant [8 x i8] c"buf_len\00" -@fld.str.551 = private constant [10 x i8] c"total_len\00" -@field_names.552 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.548, i64 1 }, { ptr, i64 } { ptr @fld.str.549, i64 3 }, { ptr, i64 } { ptr @fld.str.550, i64 7 }, { ptr, i64 } { ptr @fld.str.551, i64 9 }] -@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.554 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.555 = private constant [5 x i8] c"read\00" -@fld.str.556 = private constant [6 x i8] c"write\00" -@fld.str.557 = private constant [7 x i8] c"append\00" -@fld.str.558 = private constant [11 x i8] c"read_write\00" -@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 5 }, { ptr, i64 } { ptr @fld.str.557, i64 6 }, { ptr, i64 } { ptr @fld.str.558, i64 10 }] -@str.560 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.563 = private constant [4 x i8] c"set\00" -@fld.str.564 = private constant [8 x i8] c"current\00" -@fld.str.565 = private constant [4 x i8] c"end\00" -@field_names.566 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 3 }, { ptr, i64 } { ptr @fld.str.564, i64 7 }, { ptr, i64 } { ptr @fld.str.565, i64 3 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [6 x i8] c"null_\00" -@fld.str.571 = private constant [6 x i8] c"bool_\00" -@fld.str.572 = private constant [5 x i8] c"int_\00" -@fld.str.573 = private constant [4 x i8] c"str\00" -@fld.str.574 = private constant [6 x i8] c"array\00" -@fld.str.575 = private constant [7 x i8] c"object\00" -@field_names.576 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 5 }, { ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 4 }, { ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 6 }] -@str.577 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.579 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.580 = private constant [6 x i8] c"macos\00" -@fld.str.581 = private constant [6 x i8] c"linux\00" -@fld.str.582 = private constant [8 x i8] c"windows\00" -@fld.str.583 = private constant [5 x i8] c"wasm\00" -@fld.str.584 = private constant [4 x i8] c"ios\00" -@fld.str.585 = private constant [8 x i8] c"android\00" -@fld.str.586 = private constant [8 x i8] c"unknown\00" -@field_names.587 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 7 }] -@str.588 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.591 = private constant [8 x i8] c"aarch64\00" -@fld.str.592 = private constant [7 x i8] c"x86_64\00" -@fld.str.593 = private constant [7 x i8] c"wasm32\00" -@fld.str.594 = private constant [7 x i8] c"wasm64\00" -@fld.str.595 = private constant [8 x i8] c"unknown\00" -@field_names.596 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 6 }, { ptr, i64 } { ptr @fld.str.593, i64 6 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] -@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.603 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.604 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.607 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.632 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.633 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.634 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.635 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.636 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.637 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.638 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.639 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.640 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.642 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.645 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.648 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.651 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.654 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.657 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.666 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.669 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.672 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.675 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.678 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.681 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.684 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.687 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.693 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.696 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.699 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.702 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.705 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.708 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 -@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.711 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.717 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.720 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.723 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.342 = private constant [5 x i8] c"line\00" +@fld.str.343 = private constant [4 x i8] c"col\00" +@fld.str.344 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }, { ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 4 }] +@str.345 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.346 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.347 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.348 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.349 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.350 = private constant [4 x i8] c"ctx\00" +@fld.str.351 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.352 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.353 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.350, i64 3 }, { ptr, i64 } { ptr @fld.str.351, i64 11 }, { ptr, i64 } { ptr @fld.str.352, i64 13 }] +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.356 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.357 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.358 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.359 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.360 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.361 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.362 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.365 = private constant [12 x i8] c"alloc_count\00" +@field_names.366 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.365, i64 11 }] +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.372 = private constant [5 x i8] c"next\00" +@fld.str.373 = private constant [4 x i8] c"cap\00" +@field_names.374 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 4 }, { ptr, i64 } { ptr @fld.str.373, i64 3 }] +@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.376 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.380 = private constant [6 x i8] c"first\00" +@fld.str.381 = private constant [10 x i8] c"end_index\00" +@fld.str.382 = private constant [7 x i8] c"parent\00" +@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 5 }, { ptr, i64 } { ptr @fld.str.381, i64 9 }, { ptr, i64 } { ptr @fld.str.382, i64 6 }] +@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.385 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.389 = private constant [4 x i8] c"buf\00" +@fld.str.390 = private constant [4 x i8] c"len\00" +@fld.str.391 = private constant [4 x i8] c"pos\00" +@field_names.392 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 3 }, { ptr, i64 } { ptr @fld.str.391, i64 3 }] +@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.394 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.395 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.396 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.397 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.398 = private constant [7 x i8] c"parent\00" +@fld.str.399 = private constant [12 x i8] c"alloc_count\00" +@fld.str.400 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.401 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.402 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 6 }, { ptr, i64 } { ptr @fld.str.399, i64 11 }, { ptr, i64 } { ptr @fld.str.400, i64 13 }, { ptr, i64 } { ptr @fld.str.401, i64 17 }] +@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.404 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.408 = private constant [10 x i8] c"allocator\00" +@fld.str.409 = private constant [5 x i8] c"data\00" +@field_names.410 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 9 }, { ptr, i64 } { ptr @fld.str.409, i64 4 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [3 x i8] c"fd\00" +@field_names.417 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 2 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [5 x i8] c"file\00" +@fld.str.424 = private constant [5 x i8] c"line\00" +@fld.str.425 = private constant [4 x i8] c"col\00" +@fld.str.426 = private constant [5 x i8] c"func\00" +@fld.str.427 = private constant [10 x i8] c"line_text\00" +@field_names.428 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }, { ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 9 }] +@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.430 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.434 = private constant [10 x i8] c"exit_code\00" +@fld.str.435 = private constant [7 x i8] c"stdout\00" +@field_names.436 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 9 }, { ptr, i64 } { ptr @fld.str.435, i64 6 }] +@str.437 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.438 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.441 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.442 = private constant [8 x i8] c"sin_len\00" +@fld.str.443 = private constant [11 x i8] c"sin_family\00" +@fld.str.444 = private constant [9 x i8] c"sin_port\00" +@fld.str.445 = private constant [9 x i8] c"sin_addr\00" +@fld.str.446 = private constant [9 x i8] c"sin_zero\00" +@field_names.447 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 7 }, { ptr, i64 } { ptr @fld.str.443, i64 10 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }] +@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.449 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.453 = private constant [6 x i8] c"items\00" +@fld.str.454 = private constant [4 x i8] c"len\00" +@fld.str.455 = private constant [4 x i8] c"cap\00" +@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.462 = private constant [6 x i8] c"items\00" +@fld.str.463 = private constant [4 x i8] c"len\00" +@fld.str.464 = private constant [4 x i8] c"cap\00" +@field_names.465 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 5 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }, { ptr, i64 } { ptr @fld.str.464, i64 3 }] +@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.467 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.468 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.469 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.470 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.471 = private constant [4 x i8] c"key\00" +@fld.str.472 = private constant [4 x i8] c"val\00" +@field_names.473 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }] +@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.475 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.479 = private constant [4 x i8] c"dst\00" +@fld.str.480 = private constant [4 x i8] c"pos\00" +@fld.str.481 = private constant [5 x i8] c"file\00" +@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 4 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.488 = private constant [4 x i8] c"src\00" +@fld.str.489 = private constant [4 x i8] c"pos\00" +@fld.str.490 = private constant [6 x i8] c"alloc\00" +@field_names.491 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 5 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.497 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.499 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.503 = private constant [5 x i8] c"name\00" +@fld.str.504 = private constant [12 x i8] c"takes_value\00" +@fld.str.505 = private constant [9 x i8] c"required\00" +@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 4 }, { ptr, i64 } { ptr @fld.str.504, i64 11 }, { ptr, i64 } { ptr @fld.str.505, i64 8 }] +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.512 = private constant [6 x i8] c"group\00" +@fld.str.513 = private constant [8 x i8] c"command\00" +@fld.str.514 = private constant [6 x i8] c"flags\00" +@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 5 }, { ptr, i64 } { ptr @fld.str.513, i64 7 }, { ptr, i64 } { ptr @fld.str.514, i64 5 }] +@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.517 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.521 = private constant [4 x i8] c"set\00" +@fld.str.522 = private constant [6 x i8] c"value\00" +@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 5 }] +@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.525 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.529 = private constant [6 x i8] c"index\00" +@fld.str.530 = private constant [6 x i8] c"token\00" +@field_names.531 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 5 }, { ptr, i64 } { ptr @fld.str.530, i64 5 }] +@str.532 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.533 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.535 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.536 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.537 = private constant [6 x i8] c"group\00" +@fld.str.538 = private constant [8 x i8] c"command\00" +@fld.str.539 = private constant [10 x i8] c"cmd_index\00" +@fld.str.540 = private constant [5 x i8] c"json\00" +@fld.str.541 = private constant [5 x i8] c"rest\00" +@fld.str.542 = private constant [5 x i8] c"spec\00" +@fld.str.543 = private constant [7 x i8] c"values\00" +@field_names.544 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.537, i64 5 }, { ptr, i64 } { ptr @fld.str.538, i64 7 }, { ptr, i64 } { ptr @fld.str.539, i64 9 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 6 }] +@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.546 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.550 = private constant [2 x i8] c"h\00" +@fld.str.551 = private constant [4 x i8] c"buf\00" +@fld.str.552 = private constant [8 x i8] c"buf_len\00" +@fld.str.553 = private constant [10 x i8] c"total_len\00" +@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 1 }, { ptr, i64 } { ptr @fld.str.551, i64 3 }, { ptr, i64 } { ptr @fld.str.552, i64 7 }, { ptr, i64 } { ptr @fld.str.553, i64 9 }] +@str.555 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.556 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.557 = private constant [5 x i8] c"read\00" +@fld.str.558 = private constant [6 x i8] c"write\00" +@fld.str.559 = private constant [7 x i8] c"append\00" +@fld.str.560 = private constant [11 x i8] c"read_write\00" +@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 5 }, { ptr, i64 } { ptr @fld.str.559, i64 6 }, { ptr, i64 } { ptr @fld.str.560, i64 10 }] +@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.565 = private constant [4 x i8] c"set\00" +@fld.str.566 = private constant [8 x i8] c"current\00" +@fld.str.567 = private constant [4 x i8] c"end\00" +@field_names.568 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 7 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [6 x i8] c"null_\00" +@fld.str.573 = private constant [6 x i8] c"bool_\00" +@fld.str.574 = private constant [5 x i8] c"int_\00" +@fld.str.575 = private constant [4 x i8] c"str\00" +@fld.str.576 = private constant [6 x i8] c"array\00" +@fld.str.577 = private constant [7 x i8] c"object\00" +@field_names.578 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 4 }, { ptr, i64 } { ptr @fld.str.575, i64 3 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 6 }] +@str.579 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.581 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.582 = private constant [6 x i8] c"macos\00" +@fld.str.583 = private constant [6 x i8] c"linux\00" +@fld.str.584 = private constant [8 x i8] c"windows\00" +@fld.str.585 = private constant [5 x i8] c"wasm\00" +@fld.str.586 = private constant [4 x i8] c"ios\00" +@fld.str.587 = private constant [8 x i8] c"android\00" +@fld.str.588 = private constant [8 x i8] c"unknown\00" +@field_names.589 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.582, i64 5 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 4 }, { ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] +@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.593 = private constant [8 x i8] c"aarch64\00" +@fld.str.594 = private constant [7 x i8] c"x86_64\00" +@fld.str.595 = private constant [7 x i8] c"wasm32\00" +@fld.str.596 = private constant [7 x i8] c"wasm64\00" +@fld.str.597 = private constant [8 x i8] c"unknown\00" +@field_names.598 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 7 }] +@str.599 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.600 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.635 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.638 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.641 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.644 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.647 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.650 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.653 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.656 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.659 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.668 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.671 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.674 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.677 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.680 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.683 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.686 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.689 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.695 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.698 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.701 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.704 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.707 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.710 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 +@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.713 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.719 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.722 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.725 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -626,6 +626,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -845,7 +848,7 @@ entry: br i1 %icmp, label %if.then.66, label %if.merge.67 if.then.66: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.67: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -972,7 +975,7 @@ if.else.89: ; preds = %entry br label %if.merge.90 if.merge.90: ; preds = %if.else.89, %if.then.88 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.88 ], [ { ptr @str.127, i64 5 }, %if.else.89 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.88 ], [ { ptr @str.129, i64 5 }, %if.else.89 ] ret { ptr, i64 } %bp } @@ -1306,7 +1309,7 @@ entry: br i1 %icmp, label %if.then.379, label %if.merge.380 if.then.379: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.380: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1456,7 +1459,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1482,9 +1485,9 @@ entry: i64 11, label %match.arm.52 i64 19, label %match.arm.53 i64 20, label %match.arm.53 - i64 22, label %match.arm.53 - i64 24, label %match.arm.53 - i64 26, label %match.arm.53 + i64 21, label %match.arm.53 + i64 23, label %match.arm.53 + i64 25, label %match.arm.53 i64 27, label %match.arm.53 i64 30, label %match.arm.53 i64 32, label %match.arm.53 @@ -1526,9 +1529,9 @@ entry: i64 85, label %match.arm.58 i64 98, label %match.arm.58 i64 18, label %match.arm.59 - i64 21, label %match.arm.59 - i64 23, label %match.arm.59 - i64 25, label %match.arm.59 + i64 22, label %match.arm.59 + i64 24, label %match.arm.59 + i64 26, label %match.arm.59 i64 28, label %match.arm.59 i64 29, label %match.arm.59 i64 31, label %match.arm.59 @@ -1568,7 +1571,7 @@ match.merge.47: ; preds = %dispatch.merge.482, ret { ptr, i64 } %loadN match.arm.48: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.47 match.arm.49: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1612,9 +1615,9 @@ match.arm.53: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.105 [ i64 19, label %dispatch.case.106 i64 20, label %dispatch.case.107 - i64 22, label %dispatch.case.108 - i64 24, label %dispatch.case.109 - i64 26, label %dispatch.case.110 + i64 21, label %dispatch.case.108 + i64 23, label %dispatch.case.109 + i64 25, label %dispatch.case.110 i64 27, label %dispatch.case.111 i64 30, label %dispatch.case.112 i64 32, label %dispatch.case.113 @@ -1695,9 +1698,9 @@ match.arm.59: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.344 [ i64 18, label %dispatch.case.345 - i64 21, label %dispatch.case.346 - i64 23, label %dispatch.case.347 - i64 25, label %dispatch.case.348 + i64 22, label %dispatch.case.346 + i64 24, label %dispatch.case.347 + i64 26, label %dispatch.case.348 i64 28, label %dispatch.case.349 i64 29, label %dispatch.case.350 i64 31, label %dispatch.case.351 @@ -1795,7 +1798,7 @@ dispatch.merge.104: ; preds = %dispatch.case.130, br label %match.merge.47 dispatch.default.105: ; preds = %match.arm.53 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.106: ; preds = %match.arm.53 @@ -1809,32 +1812,32 @@ dispatch.case.106: ; preds = %match.arm.53 dispatch.case.107: ; preds = %match.arm.53 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.108: ; preds = %match.arm.53 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.109: ; preds = %match.arm.53 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.110: ; preds = %match.arm.53 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 @@ -2004,7 +2007,7 @@ dispatch.merge.256: ; preds = %dispatch.case.262, br label %match.merge.47 dispatch.default.257: ; preds = %match.arm.54 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.256 dispatch.case.258: ; preds = %match.arm.54 @@ -2045,7 +2048,7 @@ dispatch.merge.273: ; preds = %dispatch.case.280, br label %match.merge.47 dispatch.default.274: ; preds = %match.arm.57 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.273 dispatch.case.275: ; preds = %match.arm.57 @@ -2102,7 +2105,7 @@ dispatch.merge.311: ; preds = %dispatch.case.317, br label %match.merge.47 dispatch.default.312: ; preds = %match.arm.58 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.311 dispatch.case.313: ; preds = %match.arm.58 @@ -2151,7 +2154,7 @@ dispatch.merge.343: ; preds = %dispatch.case.375, br label %match.merge.47 dispatch.default.344: ; preds = %match.arm.59 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.343 dispatch.case.345: ; preds = %match.arm.59 @@ -2377,7 +2380,7 @@ dispatch.merge.482: ; preds = %dispatch.case.487, br label %match.merge.47 dispatch.default.483: ; preds = %match.arm.60 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.482 dispatch.case.484: ; preds = %match.arm.60 @@ -2419,7 +2422,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.313, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2515,7 +2518,7 @@ if.merge.21: ; preds = %if.merge.35, %if.me if.then.22: ; preds = %if.then.19 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2523,7 +2526,7 @@ if.then.22: ; preds = %if.then.19 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2533,13 +2536,13 @@ if.then.22: ; preds = %if.then.19 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.23 if.merge.23: ; preds = %if.then.22, %if.then.19 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2547,7 +2550,7 @@ if.merge.23: ; preds = %if.then.22, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2561,7 +2564,7 @@ if.merge.23: ; preds = %if.then.22, %if.the if.then.33: ; preds = %if.else.20 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2569,7 +2572,7 @@ if.then.33: ; preds = %if.else.20 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2580,7 +2583,7 @@ if.then.33: ; preds = %if.else.20 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2637,7 +2640,7 @@ if.merge.41: ; preds = %if.merge.44, %if.el if.then.42: ; preds = %if.then.39 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2645,7 +2648,7 @@ if.then.42: ; preds = %if.then.39 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2656,7 +2659,7 @@ if.then.42: ; preds = %if.then.39 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2676,7 +2679,7 @@ if.merge.44: ; preds = %if.else.43, %if.the if.then.45: ; preds = %while.exit.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2684,7 +2687,7 @@ if.then.45: ; preds = %while.exit.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, 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 @@ -2695,7 +2698,7 @@ if.then.45: ; preds = %while.exit.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.46 @@ -2705,64 +2708,67 @@ if.merge.46: ; preds = %if.then.45, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2938,163 +2944,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3292,64 +3301,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3379,97 +3388,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3508,7 +3517,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @inner(ptr %0, i32 %1) #0 { @@ -3612,7 +3621,7 @@ entry: define internal void @print__ct_s1c36e8f510df0c92__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.333, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.335, i64 15 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3628,7 +3637,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -3656,7 +3665,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.335, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.337, i64 15 }) ret { ptr, i64 } %call } @@ -3667,7 +3676,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.336, i64 15 }, { ptr, i64 } { ptr @str.337, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.338, i64 15 }, { ptr, i64 } { ptr @str.339, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3686,12 +3695,12 @@ while.body.132: ; preds = %while.hdr.131 while.exit.133: ; preds = %while.hdr.131 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 1 }) ret { ptr, i64 } %callN if.then.134: ; preds = %while.body.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.339, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.135 @@ -3703,7 +3712,7 @@ if.merge.135: ; preds = %if.then.134, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3756,20 +3765,20 @@ fv.case24: ; preds = %if.merge.135 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.344, i64 10 }, { ptr, i64 } { ptr @str.345, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.346, i64 9 }, { ptr, i64 } { ptr @str.347, 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.136 -while.hdr.136: ; preds = %if.merge.140, %entry +while.hdr.136: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.137, label %while.exit.138 while.body.137: ; preds = %while.hdr.136 @@ -3779,224 +3788,24 @@ while.body.137: ; preds = %while.hdr.136 while.exit.138: ; preds = %while.hdr.136 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 1 }) ret { ptr, i64 } %callN if.then.139: ; preds = %while.body.137 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.140 if.merge.140: ; preds = %if.then.139, %while.body.137 %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.348, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.353, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 3 }, { ptr, i64 } { ptr @str.351, 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.141 - -while.hdr.141: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.142, label %while.exit.143 - -while.body.142: ; preds = %while.hdr.141 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.144, label %if.merge.145 - -while.exit.143: ; preds = %while.hdr.141 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 1 }) - ret { ptr, i64 } %callN - -if.then.144: ; preds = %while.body.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 - -if.merge.145: ; preds = %if.then.144, %while.body.142 - %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.355, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.141 - -fv.default: ; preds = %if.merge.145 - br label %fv.merge - -fv.case: ; preds = %if.merge.145 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 10 }, { ptr, i64 } { ptr @str.358, 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.146 - -while.hdr.146: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.147, label %while.exit.148 - -while.body.147: ; preds = %while.hdr.146 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.149, label %if.merge.150 - -while.exit.148: ; preds = %while.hdr.146 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) - ret { ptr, i64 } %callN - -if.then.149: ; preds = %while.body.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.150 - -if.merge.150: ; preds = %if.then.149, %while.body.147 - %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.363, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -fv.case: ; preds = %if.merge.150 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.365, i64 9 }, { ptr, i64 } { ptr @str.366, 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.151 - -while.hdr.151: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.152, label %while.exit.153 - -while.body.152: ; preds = %while.hdr.151 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.154, label %if.merge.155 - -while.exit.153: ; preds = %while.hdr.151 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 1 }) - ret { ptr, i64 } %callN - -if.then.154: ; preds = %while.body.152 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.155 - -if.merge.155: ; preds = %if.then.154, %while.body.152 - %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.372, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, 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 @@ -4015,27 +3824,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.140 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.140 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 10 }, { ptr, i64 } { ptr @str.356, 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.141 + +while.hdr.141: ; preds = %if.merge.145, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.142, label %while.exit.143 + +while.body.142: ; preds = %while.hdr.141 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.144, label %if.merge.145 + +while.exit.143: ; preds = %while.hdr.141 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 1 }) + ret { ptr, i64 } %callN + +if.then.144: ; preds = %while.body.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.145 + +if.merge.145: ; preds = %if.then.144, %while.body.142 + %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.359, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.141 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 3 }, { ptr, i64 } { ptr @str.362, 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.146 + +while.hdr.146: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.147, label %while.exit.148 + +while.body.147: ; preds = %while.hdr.146 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.149, label %if.merge.150 + +while.exit.148: ; preds = %while.hdr.146 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 1 }) + ret { ptr, i64 } %callN + +if.then.149: ; preds = %while.body.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.150 + +if.merge.150: ; preds = %if.then.149, %while.body.147 + %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.366, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.146 + +fv.default: ; preds = %if.merge.150 + br label %fv.merge + +fv.case: ; preds = %if.merge.150 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 10 }, { ptr, i64 } { ptr @str.369, 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.151 + +while.hdr.151: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.152, label %while.exit.153 + +while.body.152: ; preds = %while.hdr.151 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.154, label %if.merge.155 + +while.exit.153: ; preds = %while.hdr.151 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.154: ; preds = %while.body.152 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.155 + +if.merge.155: ; preds = %if.then.154, %while.body.152 + %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.374, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.151 fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.155 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4045,7 +4054,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.374, i64 5 }, { ptr, i64 } { ptr @str.375, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 5 }, { ptr, i64 } { ptr @str.377, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4064,24 +4073,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %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.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.383, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, 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 @@ -4108,7 +4117,7 @@ fv.default: ; preds = %if.merge.160 fv.case: ; preds = %if.merge.160 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 @@ -4120,7 +4129,7 @@ fv.case20: ; preds = %if.merge.160 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4129,7 +4138,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 8 }, { ptr, i64 } { ptr @str.384, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4148,24 +4157,24 @@ while.body.162: ; preds = %while.hdr.161 while.exit.163: ; preds = %while.hdr.161 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) ret { ptr, i64 } %callN if.then.164: ; preds = %while.body.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.165 if.merge.165: ; preds = %if.then.164, %while.body.162 %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.390, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.392, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, 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 @@ -4212,7 +4221,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 17 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 17 }, { ptr, i64 } { ptr @str.395, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4231,24 +4240,24 @@ while.body.167: ; preds = %while.hdr.166 while.exit.168: ; preds = %while.hdr.166 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 1 }) ret { ptr, i64 } %callN if.then.169: ; preds = %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.170 if.merge.170: ; preds = %if.then.169, %while.body.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.400, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.402, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4277,7 +4286,7 @@ fv.case: ; preds = %if.merge.170 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.170 @@ -4302,7 +4311,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 7 }, { ptr, i64 } { ptr @str.403, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 7 }, { ptr, i64 } { ptr @str.405, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4321,24 +4330,24 @@ while.body.172: ; preds = %while.hdr.171 while.exit.173: ; preds = %while.hdr.171 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) ret { ptr, i64 } %callN if.then.174: ; preds = %while.body.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.175 if.merge.175: ; preds = %if.then.174, %while.body.172 %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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.410, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, 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 @@ -4365,7 +4374,7 @@ fv.case: ; preds = %if.merge.175 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.175 @@ -4380,7 +4389,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.410, i64 4 }, { ptr, i64 } { ptr @str.411, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 4 }, { ptr, i64 } { ptr @str.413, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4399,24 +4408,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4453,7 +4462,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 10 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 10 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4472,24 +4481,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4555,7 +4564,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 13 }, { ptr, i64 } { ptr @str.429, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 13 }, { ptr, i64 } { ptr @str.431, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4574,24 +4583,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %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.434, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.436, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4633,7 +4642,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 8 }, { ptr, i64 } { ptr @str.437, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 8 }, { ptr, i64 } { ptr @str.439, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4652,24 +4661,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.445, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.447, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4730,7 +4739,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 5 }, { ptr, i64 } { ptr @str.448, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 5 }, { ptr, i64 } { ptr @str.450, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4749,24 +4758,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.456, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, 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 @@ -4812,7 +4821,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 6 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4831,24 +4840,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %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.463, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.465, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, 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 @@ -4896,7 +4905,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 6 }, { ptr, i64 } { ptr @str.468, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4915,24 +4924,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.471, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.473, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4976,7 +4985,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 4 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 4 }, { ptr, i64 } { ptr @str.476, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4995,24 +5004,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.482, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5062,7 +5071,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 6 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 6 }, { ptr, i64 } { ptr @str.485, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5081,24 +5090,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5138,7 +5147,7 @@ fv.case20: ; preds = %if.merge.220 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5147,7 +5156,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 12 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 12 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5166,24 +5175,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.495, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.497, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5203,7 +5212,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 8 }, { ptr, i64 } { ptr @str.498, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 8 }, { ptr, i64 } { ptr @str.500, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5222,24 +5231,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.506, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5291,7 +5300,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 7 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 7 }, { ptr, i64 } { ptr @str.509, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5310,24 +5319,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.513, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.515, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5379,7 +5388,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 9 }, { ptr, i64 } { ptr @str.516, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 9 }, { ptr, i64 } { ptr @str.518, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5398,24 +5407,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %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.521, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.523, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5458,7 +5467,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 4 }, { ptr, i64 } { ptr @str.524, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 4 }, { ptr, i64 } { ptr @str.526, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5477,24 +5486,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %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.529, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.531, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5540,7 +5549,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 6 }, { ptr, i64 } { ptr @str.532, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.533, i64 6 }, { ptr, i64 } { ptr @str.534, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5559,24 +5568,24 @@ while.body.247: ; preds = %while.hdr.246 while.exit.248: ; preds = %while.hdr.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 1 }) ret { ptr, i64 } %callN if.then.249: ; preds = %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.250 if.merge.250: ; preds = %if.then.249, %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.542, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.544, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5658,7 +5667,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.544, i64 6 }, { ptr, i64 } { ptr @str.545, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5677,24 +5686,24 @@ while.body.252: ; preds = %while.hdr.251 while.exit.253: ; preds = %while.hdr.251 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) ret { ptr, i64 } %callN if.then.254: ; preds = %while.body.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.255 if.merge.255: ; preds = %if.then.254, %while.body.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.552, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5753,9 +5762,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, 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 @@ -5774,8 +5783,8 @@ entry: if.then.263: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 @@ -5794,9 +5803,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, 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 @@ -5815,8 +5824,8 @@ entry: if.then.265: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -5846,9 +5855,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.576, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.578, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5865,8 +5874,8 @@ entry: if.then.267: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -5944,9 +5953,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.587, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, 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 @@ -5965,8 +5974,8 @@ entry: if.then.269: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 @@ -5985,9 +5994,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, 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 @@ -6006,8 +6015,8 @@ entry: if.then.271: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 @@ -6024,7 +6033,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6041,12 +6050,12 @@ while.body.282: ; preds = %while.hdr.281 while.exit.283: ; preds = %while.hdr.281 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %call if.then.284: ; preds = %while.body.282 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -6075,7 +6084,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6092,12 +6101,12 @@ while.body.287: ; preds = %while.hdr.286 while.exit.288: ; preds = %while.hdr.286 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) ret { ptr, i64 } %call if.then.289: ; preds = %while.body.287 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6127,7 +6136,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6144,12 +6153,12 @@ while.body.292: ; preds = %while.hdr.291 while.exit.293: ; preds = %while.hdr.291 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) ret { ptr, i64 } %call if.then.294: ; preds = %while.body.292 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.295 @@ -6177,7 +6186,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6194,12 +6203,12 @@ while.body.297: ; preds = %while.hdr.296 while.exit.298: ; preds = %while.hdr.296 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) ret { ptr, i64 } %call if.then.299: ; preds = %while.body.297 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6228,7 +6237,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6245,12 +6254,12 @@ while.body.302: ; preds = %while.hdr.301 while.exit.303: ; preds = %while.hdr.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) ret { ptr, i64 } %call if.then.304: ; preds = %while.body.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 @@ -6279,7 +6288,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.306 @@ -6296,12 +6305,12 @@ while.body.307: ; preds = %while.hdr.306 while.exit.308: ; preds = %while.hdr.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) ret { ptr, i64 } %call if.then.309: ; preds = %while.body.307 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.310 @@ -6331,7 +6340,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6350,12 +6359,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6384,7 +6393,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6403,12 +6412,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -6437,7 +6446,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -6456,12 +6465,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -6491,7 +6500,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.333 @@ -6510,12 +6519,12 @@ while.body.334: ; preds = %while.hdr.333 while.exit.335: ; preds = %while.hdr.333 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) ret { ptr, i64 } %call if.then.336: ; preds = %while.body.334 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.337 @@ -6545,7 +6554,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.631, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.338 @@ -6564,12 +6573,12 @@ while.body.339: ; preds = %while.hdr.338 while.exit.340: ; preds = %while.hdr.338 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) ret { ptr, i64 } %call if.then.341: ; preds = %while.body.339 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.342 @@ -6611,12 +6620,12 @@ if.then.376: ; preds = %entry if.else.377: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.633, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 5 }, { ptr, i64 } %callN) br label %if.merge.378 if.merge.378: ; preds = %if.else.377, %if.then.376 - %bp = phi { ptr, i64 } [ { ptr @str.632, i64 4 }, %if.then.376 ], [ %callN, %if.else.377 ] + %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.376 ], [ %callN, %if.else.377 ] ret { ptr, i64 } %bp } @@ -6639,12 +6648,12 @@ if.then.392: ; preds = %entry if.else.393: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 11 }, { ptr, i64 } %callN) br label %if.merge.394 if.merge.394: ; preds = %if.else.393, %if.then.392 - %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.392 ], [ %callN, %if.else.393 ] + %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.392 ], [ %callN, %if.else.393 ] ret { ptr, i64 } %bp } @@ -6667,12 +6676,12 @@ if.then.395: ; preds = %entry if.else.396: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 4 }, { ptr, i64 } %callN) br label %if.merge.397 if.merge.397: ; preds = %if.else.396, %if.then.395 - %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.395 ], [ %callN, %if.else.396 ] + %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.395 ], [ %callN, %if.else.396 ] ret { ptr, i64 } %bp } @@ -6695,12 +6704,12 @@ if.then.398: ; preds = %entry if.else.399: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 11 }, { ptr, i64 } %callN) br label %if.merge.400 if.merge.400: ; preds = %if.else.399, %if.then.398 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.398 ], [ %callN, %if.else.399 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.398 ], [ %callN, %if.else.399 ] ret { ptr, i64 } %bp } @@ -6723,12 +6732,12 @@ if.then.401: ; preds = %entry if.else.402: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 6 }, { ptr, i64 } %callN) br label %if.merge.403 if.merge.403: ; preds = %if.else.402, %if.then.401 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] ret { ptr, i64 } %bp } @@ -6750,12 +6759,12 @@ if.then.404: ; preds = %entry if.else.405: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 5 }, { ptr, i64 } %callN) br label %if.merge.406 if.merge.406: ; preds = %if.else.405, %if.then.404 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.404 ], [ %callN, %if.else.405 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.404 ], [ %callN, %if.else.405 ] ret { ptr, i64 } %bp } @@ -6778,12 +6787,12 @@ if.then.407: ; preds = %entry if.else.408: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 9 }, { ptr, i64 } %callN) br label %if.merge.409 if.merge.409: ; preds = %if.else.408, %if.then.407 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] ret { ptr, i64 } %bp } @@ -6806,12 +6815,12 @@ if.then.410: ; preds = %entry if.else.411: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 18 }, { ptr, i64 } %callN) br label %if.merge.412 if.merge.412: ; preds = %if.else.411, %if.then.410 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.410 ], [ %callN, %if.else.411 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.410 ], [ %callN, %if.else.411 ] ret { ptr, i64 } %bp } @@ -6834,12 +6843,12 @@ if.then.413: ; preds = %entry if.else.414: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 5 }, { ptr, i64 } %callN) br label %if.merge.415 if.merge.415: ; preds = %if.else.414, %if.then.413 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.413 ], [ %callN, %if.else.414 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.413 ], [ %callN, %if.else.414 ] ret { ptr, i64 } %bp } @@ -6862,12 +6871,12 @@ if.then.416: ; preds = %entry if.else.417: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %callN) br label %if.merge.418 if.merge.418: ; preds = %if.else.417, %if.then.416 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.416 ], [ %callN, %if.else.417 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.416 ], [ %callN, %if.else.417 ] ret { ptr, i64 } %bp } @@ -6890,12 +6899,12 @@ if.then.419: ; preds = %entry if.else.420: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 4 }, { ptr, i64 } %callN) br label %if.merge.421 if.merge.421: ; preds = %if.else.420, %if.then.419 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.419 ], [ %callN, %if.else.420 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.419 ], [ %callN, %if.else.420 ] ret { ptr, i64 } %bp } @@ -6918,12 +6927,12 @@ if.then.422: ; preds = %entry if.else.423: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 9 }, { ptr, i64 } %callN) br label %if.merge.424 if.merge.424: ; preds = %if.else.423, %if.then.422 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] ret { ptr, i64 } %bp } @@ -6946,12 +6955,12 @@ if.then.425: ; preds = %entry if.else.426: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 4 }, { ptr, i64 } %callN) br label %if.merge.427 if.merge.427: ; preds = %if.else.426, %if.then.425 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -6973,12 +6982,12 @@ if.then.428: ; preds = %entry if.else.429: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 8 }, { ptr, i64 } %callN) br label %if.merge.430 if.merge.430: ; preds = %if.else.429, %if.then.428 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7001,12 +7010,12 @@ if.then.431: ; preds = %entry if.else.432: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 6 }, { ptr, i64 } %callN) br label %if.merge.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7028,12 +7037,12 @@ if.then.434: ; preds = %entry if.else.435: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 9 }, { ptr, i64 } %callN) br label %if.merge.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7056,12 +7065,12 @@ if.then.437: ; preds = %entry if.else.438: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 7 }, { ptr, i64 } %callN) br label %if.merge.439 if.merge.439: ; preds = %if.else.438, %if.then.437 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7084,12 +7093,12 @@ if.then.440: ; preds = %entry if.else.441: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 5 }, { ptr, i64 } %callN) br label %if.merge.442 if.merge.442: ; preds = %if.else.441, %if.then.440 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7112,12 +7121,12 @@ if.then.443: ; preds = %entry if.else.444: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) br label %if.merge.445 if.merge.445: ; preds = %if.else.444, %if.then.443 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7140,12 +7149,12 @@ if.then.446: ; preds = %entry if.else.447: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 4 }, { ptr, i64 } %callN) br label %if.merge.448 if.merge.448: ; preds = %if.else.447, %if.then.446 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7168,12 +7177,12 @@ if.then.449: ; preds = %entry if.else.450: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) br label %if.merge.451 if.merge.451: ; preds = %if.else.450, %if.then.449 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7196,12 +7205,12 @@ if.then.452: ; preds = %entry if.else.453: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 5 }, { ptr, i64 } %callN) br label %if.merge.454 if.merge.454: ; preds = %if.else.453, %if.then.452 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7224,12 +7233,12 @@ if.then.455: ; preds = %entry if.else.456: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 7 }, { ptr, i64 } %callN) br label %if.merge.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7252,12 +7261,12 @@ if.then.458: ; preds = %entry if.else.459: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 12 }, { ptr, i64 } %callN) br label %if.merge.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7280,12 +7289,12 @@ if.then.461: ; preds = %entry if.else.462: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 6 }, { ptr, i64 } %callN) br label %if.merge.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7308,12 +7317,12 @@ if.then.464: ; preds = %entry if.else.465: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 10 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 10 }, { ptr, i64 } %callN) br label %if.merge.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7336,12 +7345,12 @@ if.then.467: ; preds = %entry if.else.468: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 7 }, { ptr, i64 } %callN) br label %if.merge.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7364,12 +7373,12 @@ if.then.470: ; preds = %entry if.else.471: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 4 }, { ptr, i64 } %callN) br label %if.merge.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7392,12 +7401,12 @@ if.then.473: ; preds = %entry if.else.474: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 7 }, { ptr, i64 } %callN) br label %if.merge.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7420,12 +7429,12 @@ if.then.476: ; preds = %entry if.else.477: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 6 }, { ptr, i64 } %callN) br label %if.merge.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7448,12 +7457,12 @@ if.then.479: ; preds = %entry if.else.480: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 5 }, { ptr, i64 } %callN) br label %if.merge.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7469,7 +7478,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.725, i64 4 } + ret { ptr, i64 } { ptr @str.727, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7493,7 +7502,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.726, i64 4 } + ret { ptr, i64 } { ptr @str.728, i64 4 } if.merge.491: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7517,7 +7526,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.493: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7541,7 +7550,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.495: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/1006-errors-inferred-error-sets.ir b/examples/expected/1006-errors-inferred-error-sets.ir index 8b6c250..ce2b340 100644 --- a/examples/expected/1006-errors-inferred-error-sets.ir +++ b/examples/expected/1006-errors-inferred-error-sets.ir @@ -1,625 +1,625 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.127 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.128 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.130 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.131 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.129 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.130 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.131 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.132 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.133 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [163 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.132 = private constant [9 x i8] c"Overflow\00" -@tag.str.133 = private constant [3 x i8] c"Io\00" -@tag.str.134 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.135 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.136 = private constant [10 x i8] c"BadEscape\00" -@tag.str.137 = private constant [10 x i8] c"BadNumber\00" -@tag.str.138 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.139 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.140 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.141 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.142 = private constant [13 x i8] c"MissingValue\00" -@tag.str.143 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.144 = private constant [13 x i8] c"TooManyFlags\00" -@tag.str.145 = private constant [4 x i8] c"Foo\00" -@tag.str.146 = private constant [4 x i8] c"Bar\00" -@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.132, i64 8 }, { ptr, i64 } { ptr @tag.str.133, i64 2 }, { ptr, i64 } { ptr @tag.str.134, i64 15 }, { ptr, i64 } { ptr @tag.str.135, i64 13 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 15 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 11 }, { ptr, i64 } { ptr @tag.str.142, i64 12 }, { ptr, i64 } { ptr @tag.str.143, i64 15 }, { ptr, i64 } { ptr @tag.str.144, i64 12 }, { ptr, i64 } { ptr @tag.str.145, i64 3 }, { ptr, i64 } { ptr @tag.str.146, i64 3 }] +@tag.str.134 = private constant [9 x i8] c"Overflow\00" +@tag.str.135 = private constant [3 x i8] c"Io\00" +@tag.str.136 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.137 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.138 = private constant [10 x i8] c"BadEscape\00" +@tag.str.139 = private constant [10 x i8] c"BadNumber\00" +@tag.str.140 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.141 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.142 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.143 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.144 = private constant [13 x i8] c"MissingValue\00" +@tag.str.145 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.146 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.147 = private constant [4 x i8] c"Foo\00" +@tag.str.148 = private constant [4 x i8] c"Bar\00" +@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.134, i64 8 }, { ptr, i64 } { ptr @tag.str.135, i64 2 }, { ptr, i64 } { ptr @tag.str.136, i64 15 }, { ptr, i64 } { ptr @tag.str.137, i64 13 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 15 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 11 }, { ptr, i64 } { ptr @tag.str.144, i64 12 }, { ptr, i64 } { ptr @tag.str.145, i64 15 }, { ptr, i64 } { ptr @tag.str.146, i64 12 }, { ptr, i64 } { ptr @tag.str.147, i64 3 }, { ptr, i64 } { ptr @tag.str.148, i64 3 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.147 = private constant [5 x i8] c"bool\00" -@tn.str.148 = private constant [3 x i8] c"s8\00" -@tn.str.149 = private constant [4 x i8] c"s16\00" -@tn.str.150 = private constant [4 x i8] c"s32\00" -@tn.str.151 = private constant [4 x i8] c"s64\00" -@tn.str.152 = private constant [3 x i8] c"u8\00" -@tn.str.153 = private constant [4 x i8] c"u16\00" -@tn.str.154 = private constant [4 x i8] c"u32\00" -@tn.str.155 = private constant [4 x i8] c"u64\00" -@tn.str.156 = private constant [4 x i8] c"f32\00" -@tn.str.157 = private constant [4 x i8] c"f64\00" -@tn.str.158 = private constant [7 x i8] c"string\00" -@tn.str.159 = private constant [4 x i8] c"Any\00" -@tn.str.160 = private constant [9 x i8] c"noreturn\00" -@tn.str.161 = private constant [6 x i8] c"isize\00" -@tn.str.162 = private constant [6 x i8] c"usize\00" -@tn.str.163 = private constant [5 x i8] c"void\00" -@tn.str.164 = private constant [6 x i8] c"*void\00" -@tn.str.165 = private constant [16 x i8] c"Source_Location\00" -@tn.str.166 = private constant [11 x i8] c"CAllocator\00" -@tn.str.167 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.168 = private constant [4 x i8] c"GPA\00" -@tn.str.169 = private constant [5 x i8] c"*GPA\00" -@tn.str.170 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.171 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.172 = private constant [10 x i8] c"Allocator\00" -@tn.str.173 = private constant [6 x i8] c"Arena\00" -@tn.str.174 = private constant [7 x i8] c"*Arena\00" -@tn.str.175 = private constant [6 x i8] c"[*]u8\00" -@tn.str.176 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.177 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.178 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.179 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.180 = private constant [8 x i8] c"Context\00" -@tn.str.181 = private constant [7 x i8] c"[4]s64\00" -@tn.str.182 = private constant [9 x i8] c"[]string\00" -@tn.str.183 = private constant [9 x i8] c"OpenMode\00" -@tn.str.184 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.185 = private constant [5 x i8] c"File\00" -@tn.str.186 = private constant [6 x i8] c"*File\00" -@tn.str.187 = private constant [6 x i8] c"?File\00" -@tn.str.188 = private constant [8 x i8] c"?string\00" -@tn.str.189 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.190 = private constant [4 x i8] c"*u8\00" -@tn.str.191 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.192 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.193 = private constant [5 x i8] c"*s32\00" -@tn.str.194 = private constant [9 x i8] c"SockAddr\00" -@tn.str.195 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.196 = private constant [5 x i8] c"*u32\00" -@tn.str.197 = private constant [10 x i8] c"JsonError\00" -@tn.str.198 = private constant [6 x i8] c"Array\00" -@tn.str.199 = private constant [7 x i8] c"Object\00" -@tn.str.200 = private constant [6 x i8] c"Value\00" -@tn.str.201 = private constant [7 x i8] c"Member\00" -@tn.str.202 = private constant [9 x i8] c"[*]Value\00" -@tn.str.203 = private constant [7 x i8] c"*Array\00" -@tn.str.204 = private constant [10 x i8] c"[*]Member\00" -@tn.str.205 = private constant [8 x i8] c"*Object\00" -@tn.str.206 = private constant [5 x i8] c"[]u8\00" -@tn.str.207 = private constant [5 x i8] c"Sink\00" -@tn.str.208 = private constant [6 x i8] c"*Sink\00" -@tn.str.209 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.210 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.211 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.212 = private constant [7 x i8] c"Parser\00" -@tn.str.213 = private constant [8 x i8] c"*Parser\00" -@tn.str.214 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.215 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.216 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.217 = private constant [13 x i8] c"Architecture\00" -@tn.str.218 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.219 = private constant [11 x i8] c"() -> bool\00" -@tn.str.220 = private constant [5 x i8] c"*s64\00" -@tn.str.221 = private constant [9 x i8] c"CliError\00" -@tn.str.222 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.223 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.224 = private constant [8 x i8] c"Command\00" -@tn.str.225 = private constant [10 x i8] c"FlagValue\00" -@tn.str.226 = private constant [5 x i8] c"Diag\00" -@tn.str.227 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.228 = private constant [7 x i8] c"Parsed\00" -@tn.str.229 = private constant [8 x i8] c"*Parsed\00" -@tn.str.230 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.231 = private constant [10 x i8] c"[]Command\00" -@tn.str.232 = private constant [6 x i8] c"*Diag\00" -@tn.str.233 = private constant [7 x i8] c"[8]s64\00" -@tn.str.234 = private constant [7 x i8] c"[64]u8\00" -@tn.str.235 = private constant [7 x i8] c"Sha256\00" -@tn.str.236 = private constant [8 x i8] c"*Sha256\00" -@tn.str.237 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.238 = private constant [8 x i8] c"[64]s64\00" -@tn.str.239 = private constant [2 x i8] c"A\00" -@tn.str.240 = private constant [2 x i8] c"!\00" -@tn.str.241 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.242 = private constant [7 x i8] c"**void\00" -@tn.str.243 = private constant [3 x i8] c"*A\00" -@tn.str.244 = private constant [8 x i8] c"*string\00" -@tn.str.245 = private constant [6 x i8] c"[]Any\00" -@tn.str.246 = private constant [5 x i8] c"*Any\00" -@tn.str.247 = private constant [7 x i8] c"[1]Any\00" -@tn.str.248 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.249 = private constant [7 x i8] c"*[]Any\00" -@tn.str.250 = private constant [6 x i8] c"*bool\00" -@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.252 = private constant [5 x i8] c"*f64\00" -@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.254 = private constant [11 x i8] c"*Allocator\00" -@tn.str.255 = private constant [9 x i8] c"*Context\00" -@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.258 = private constant [8 x i8] c"*Member\00" -@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.261 = private constant [9 x i8] c"*Command\00" -@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.265 = private constant [7 x i8] c"*Value\00" -@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.267 = private constant [14 x i8] c"*Architecture\00" -@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.272 = private constant [10 x i8] c"*[]string\00" -@tn.str.273 = private constant [6 x i8] c"*[]u8\00" -@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.275 = private constant [11 x i8] c"*[]Command\00" -@tn.str.276 = private constant [6 x i8] c"**GPA\00" -@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.278 = private constant [8 x i8] c"**Arena\00" -@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.282 = private constant [7 x i8] c"**File\00" -@tn.str.283 = private constant [5 x i8] c"**u8\00" -@tn.str.284 = private constant [6 x i8] c"**s32\00" -@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.286 = private constant [6 x i8] c"**u32\00" -@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.288 = private constant [8 x i8] c"**Array\00" -@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.290 = private constant [9 x i8] c"**Object\00" -@tn.str.291 = private constant [7 x i8] c"**Sink\00" -@tn.str.292 = private constant [9 x i8] c"**Parser\00" -@tn.str.293 = private constant [6 x i8] c"**s64\00" -@tn.str.294 = private constant [9 x i8] c"**Parsed\00" -@tn.str.295 = private constant [7 x i8] c"**Diag\00" -@tn.str.296 = private constant [9 x i8] c"**Sha256\00" -@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.298 = private constant [8 x i8] c"***void\00" -@tn.str.299 = private constant [4 x i8] c"**A\00" -@tn.str.300 = private constant [9 x i8] c"**string\00" -@tn.str.301 = private constant [6 x i8] c"**Any\00" -@tn.str.302 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.303 = private constant [8 x i8] c"**[]Any\00" -@tn.str.304 = private constant [7 x i8] c"**bool\00" -@tn.str.305 = private constant [7 x i8] c"*?File\00" -@tn.str.306 = private constant [9 x i8] c"*?string\00" -@tn.str.307 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.308 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [163 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.147, i64 4 }, { ptr, i64 } { ptr @tn.str.148, i64 2 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 2 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 3 }, { ptr, i64 } { ptr @tn.str.158, i64 6 }, { ptr, i64 } { ptr @tn.str.159, i64 3 }, { ptr, i64 } { ptr @tn.str.160, i64 8 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 5 }, { ptr, i64 } { ptr @tn.str.163, i64 4 }, { ptr, i64 } { ptr @tn.str.164, i64 5 }, { ptr, i64 } { ptr @tn.str.165, i64 15 }, { ptr, i64 } { ptr @tn.str.166, i64 10 }, { ptr, i64 } { ptr @tn.str.167, i64 11 }, { ptr, i64 } { ptr @tn.str.168, i64 3 }, { ptr, i64 } { ptr @tn.str.169, i64 4 }, { ptr, i64 } { ptr @tn.str.170, i64 10 }, { ptr, i64 } { ptr @tn.str.171, i64 11 }, { ptr, i64 } { ptr @tn.str.172, i64 9 }, { ptr, i64 } { ptr @tn.str.173, i64 5 }, { ptr, i64 } { ptr @tn.str.174, i64 6 }, { ptr, i64 } { ptr @tn.str.175, i64 5 }, { ptr, i64 } { ptr @tn.str.176, i64 8 }, { ptr, i64 } { ptr @tn.str.177, i64 9 }, { ptr, i64 } { ptr @tn.str.178, i64 17 }, { ptr, i64 } { ptr @tn.str.179, i64 18 }, { ptr, i64 } { ptr @tn.str.180, i64 7 }, { ptr, i64 } { ptr @tn.str.181, i64 6 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 8 }, { ptr, i64 } { ptr @tn.str.185, i64 4 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 5 }, { ptr, i64 } { ptr @tn.str.188, i64 7 }, { ptr, i64 } { ptr @tn.str.189, i64 10 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 13 }, { ptr, i64 } { ptr @tn.str.192, i64 14 }, { ptr, i64 } { ptr @tn.str.193, i64 4 }, { ptr, i64 } { ptr @tn.str.194, i64 8 }, { ptr, i64 } { ptr @tn.str.195, i64 9 }, { ptr, i64 } { ptr @tn.str.196, i64 4 }, { ptr, i64 } { ptr @tn.str.197, i64 9 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 6 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 6 }, { ptr, i64 } { ptr @tn.str.202, i64 8 }, { ptr, i64 } { ptr @tn.str.203, i64 6 }, { ptr, i64 } { ptr @tn.str.204, i64 9 }, { ptr, i64 } { ptr @tn.str.205, i64 7 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 4 }, { ptr, i64 } { ptr @tn.str.208, i64 5 }, { ptr, i64 } { ptr @tn.str.209, i64 16 }, { ptr, i64 } { ptr @tn.str.210, i64 14 }, { ptr, i64 } { ptr @tn.str.211, i64 21 }, { ptr, i64 } { ptr @tn.str.212, i64 6 }, { ptr, i64 } { ptr @tn.str.213, i64 7 }, { ptr, i64 } { ptr @tn.str.214, i64 24 }, { ptr, i64 } { ptr @tn.str.215, i64 23 }, { ptr, i64 } { ptr @tn.str.216, i64 15 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 12 }, { ptr, i64 } { ptr @tn.str.219, i64 10 }, { ptr, i64 } { ptr @tn.str.220, i64 4 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 10 }, { ptr, i64 } { ptr @tn.str.224, i64 7 }, { ptr, i64 } { ptr @tn.str.225, i64 9 }, { ptr, i64 } { ptr @tn.str.226, i64 4 }, { ptr, i64 } { ptr @tn.str.227, i64 13 }, { ptr, i64 } { ptr @tn.str.228, i64 6 }, { ptr, i64 } { ptr @tn.str.229, i64 7 }, { ptr, i64 } { ptr @tn.str.230, i64 18 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 5 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 1 }, { ptr, i64 } { ptr @tn.str.240, i64 1 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 2 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 3 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 15 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }] -@str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.149 = private constant [5 x i8] c"bool\00" +@tn.str.150 = private constant [3 x i8] c"s8\00" +@tn.str.151 = private constant [4 x i8] c"s16\00" +@tn.str.152 = private constant [4 x i8] c"s32\00" +@tn.str.153 = private constant [4 x i8] c"s64\00" +@tn.str.154 = private constant [3 x i8] c"u8\00" +@tn.str.155 = private constant [4 x i8] c"u16\00" +@tn.str.156 = private constant [4 x i8] c"u32\00" +@tn.str.157 = private constant [4 x i8] c"u64\00" +@tn.str.158 = private constant [4 x i8] c"f32\00" +@tn.str.159 = private constant [4 x i8] c"f64\00" +@tn.str.160 = private constant [7 x i8] c"string\00" +@tn.str.161 = private constant [4 x i8] c"Any\00" +@tn.str.162 = private constant [9 x i8] c"noreturn\00" +@tn.str.163 = private constant [6 x i8] c"isize\00" +@tn.str.164 = private constant [6 x i8] c"usize\00" +@tn.str.165 = private constant [5 x i8] c"void\00" +@tn.str.166 = private constant [6 x i8] c"*void\00" +@tn.str.167 = private constant [16 x i8] c"Source_Location\00" +@tn.str.168 = private constant [10 x i8] c"Allocator\00" +@tn.str.169 = private constant [11 x i8] c"CAllocator\00" +@tn.str.170 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.171 = private constant [4 x i8] c"GPA\00" +@tn.str.172 = private constant [5 x i8] c"*GPA\00" +@tn.str.173 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.174 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.175 = private constant [6 x i8] c"Arena\00" +@tn.str.176 = private constant [7 x i8] c"*Arena\00" +@tn.str.177 = private constant [6 x i8] c"[*]u8\00" +@tn.str.178 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.179 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.180 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.181 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.182 = private constant [8 x i8] c"Context\00" +@tn.str.183 = private constant [7 x i8] c"[4]s64\00" +@tn.str.184 = private constant [9 x i8] c"[]string\00" +@tn.str.185 = private constant [9 x i8] c"OpenMode\00" +@tn.str.186 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.187 = private constant [5 x i8] c"File\00" +@tn.str.188 = private constant [6 x i8] c"*File\00" +@tn.str.189 = private constant [6 x i8] c"?File\00" +@tn.str.190 = private constant [8 x i8] c"?string\00" +@tn.str.191 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.192 = private constant [4 x i8] c"*u8\00" +@tn.str.193 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.194 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.195 = private constant [5 x i8] c"*s32\00" +@tn.str.196 = private constant [9 x i8] c"SockAddr\00" +@tn.str.197 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.198 = private constant [5 x i8] c"*u32\00" +@tn.str.199 = private constant [10 x i8] c"JsonError\00" +@tn.str.200 = private constant [6 x i8] c"Array\00" +@tn.str.201 = private constant [7 x i8] c"Object\00" +@tn.str.202 = private constant [6 x i8] c"Value\00" +@tn.str.203 = private constant [7 x i8] c"Member\00" +@tn.str.204 = private constant [9 x i8] c"[*]Value\00" +@tn.str.205 = private constant [7 x i8] c"*Array\00" +@tn.str.206 = private constant [10 x i8] c"[*]Member\00" +@tn.str.207 = private constant [8 x i8] c"*Object\00" +@tn.str.208 = private constant [5 x i8] c"[]u8\00" +@tn.str.209 = private constant [5 x i8] c"Sink\00" +@tn.str.210 = private constant [6 x i8] c"*Sink\00" +@tn.str.211 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.212 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.213 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.214 = private constant [7 x i8] c"Parser\00" +@tn.str.215 = private constant [8 x i8] c"*Parser\00" +@tn.str.216 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.217 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.218 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.219 = private constant [13 x i8] c"Architecture\00" +@tn.str.220 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.221 = private constant [11 x i8] c"() -> bool\00" +@tn.str.222 = private constant [5 x i8] c"*s64\00" +@tn.str.223 = private constant [9 x i8] c"CliError\00" +@tn.str.224 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.225 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.226 = private constant [8 x i8] c"Command\00" +@tn.str.227 = private constant [10 x i8] c"FlagValue\00" +@tn.str.228 = private constant [5 x i8] c"Diag\00" +@tn.str.229 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.230 = private constant [7 x i8] c"Parsed\00" +@tn.str.231 = private constant [8 x i8] c"*Parsed\00" +@tn.str.232 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.233 = private constant [10 x i8] c"[]Command\00" +@tn.str.234 = private constant [6 x i8] c"*Diag\00" +@tn.str.235 = private constant [7 x i8] c"[8]s64\00" +@tn.str.236 = private constant [7 x i8] c"[64]u8\00" +@tn.str.237 = private constant [7 x i8] c"Sha256\00" +@tn.str.238 = private constant [8 x i8] c"*Sha256\00" +@tn.str.239 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.240 = private constant [8 x i8] c"[64]s64\00" +@tn.str.241 = private constant [2 x i8] c"A\00" +@tn.str.242 = private constant [2 x i8] c"!\00" +@tn.str.243 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.244 = private constant [7 x i8] c"**void\00" +@tn.str.245 = private constant [3 x i8] c"*A\00" +@tn.str.246 = private constant [8 x i8] c"*string\00" +@tn.str.247 = private constant [6 x i8] c"[]Any\00" +@tn.str.248 = private constant [5 x i8] c"*Any\00" +@tn.str.249 = private constant [7 x i8] c"[1]Any\00" +@tn.str.250 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.251 = private constant [7 x i8] c"*[]Any\00" +@tn.str.252 = private constant [6 x i8] c"*bool\00" +@tn.str.253 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.254 = private constant [5 x i8] c"*f64\00" +@tn.str.255 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.256 = private constant [11 x i8] c"*Allocator\00" +@tn.str.257 = private constant [9 x i8] c"*Context\00" +@tn.str.258 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.259 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.260 = private constant [8 x i8] c"*Member\00" +@tn.str.261 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.262 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.263 = private constant [9 x i8] c"*Command\00" +@tn.str.264 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.265 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.266 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.267 = private constant [7 x i8] c"*Value\00" +@tn.str.268 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.269 = private constant [14 x i8] c"*Architecture\00" +@tn.str.270 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.271 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.272 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.273 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.274 = private constant [10 x i8] c"*[]string\00" +@tn.str.275 = private constant [6 x i8] c"*[]u8\00" +@tn.str.276 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.277 = private constant [11 x i8] c"*[]Command\00" +@tn.str.278 = private constant [6 x i8] c"**GPA\00" +@tn.str.279 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.280 = private constant [8 x i8] c"**Arena\00" +@tn.str.281 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.282 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.283 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.284 = private constant [7 x i8] c"**File\00" +@tn.str.285 = private constant [5 x i8] c"**u8\00" +@tn.str.286 = private constant [6 x i8] c"**s32\00" +@tn.str.287 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.288 = private constant [6 x i8] c"**u32\00" +@tn.str.289 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.290 = private constant [8 x i8] c"**Array\00" +@tn.str.291 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.292 = private constant [9 x i8] c"**Object\00" +@tn.str.293 = private constant [7 x i8] c"**Sink\00" +@tn.str.294 = private constant [9 x i8] c"**Parser\00" +@tn.str.295 = private constant [6 x i8] c"**s64\00" +@tn.str.296 = private constant [9 x i8] c"**Parsed\00" +@tn.str.297 = private constant [7 x i8] c"**Diag\00" +@tn.str.298 = private constant [9 x i8] c"**Sha256\00" +@tn.str.299 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.300 = private constant [8 x i8] c"***void\00" +@tn.str.301 = private constant [4 x i8] c"**A\00" +@tn.str.302 = private constant [9 x i8] c"**string\00" +@tn.str.303 = private constant [6 x i8] c"**Any\00" +@tn.str.304 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.305 = private constant [8 x i8] c"**[]Any\00" +@tn.str.306 = private constant [7 x i8] c"**bool\00" +@tn.str.307 = private constant [7 x i8] c"*?File\00" +@tn.str.308 = private constant [9 x i8] c"*?string\00" +@tn.str.309 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.310 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [163 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.149, i64 4 }, { ptr, i64 } { ptr @tn.str.150, i64 2 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 2 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 3 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 3 }, { ptr, i64 } { ptr @tn.str.160, i64 6 }, { ptr, i64 } { ptr @tn.str.161, i64 3 }, { ptr, i64 } { ptr @tn.str.162, i64 8 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 5 }, { ptr, i64 } { ptr @tn.str.165, i64 4 }, { ptr, i64 } { ptr @tn.str.166, i64 5 }, { ptr, i64 } { ptr @tn.str.167, i64 15 }, { ptr, i64 } { ptr @tn.str.168, i64 9 }, { ptr, i64 } { ptr @tn.str.169, i64 10 }, { ptr, i64 } { ptr @tn.str.170, i64 11 }, { ptr, i64 } { ptr @tn.str.171, i64 3 }, { ptr, i64 } { ptr @tn.str.172, i64 4 }, { ptr, i64 } { ptr @tn.str.173, i64 10 }, { ptr, i64 } { ptr @tn.str.174, i64 11 }, { ptr, i64 } { ptr @tn.str.175, i64 5 }, { ptr, i64 } { ptr @tn.str.176, i64 6 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 8 }, { ptr, i64 } { ptr @tn.str.179, i64 9 }, { ptr, i64 } { ptr @tn.str.180, i64 17 }, { ptr, i64 } { ptr @tn.str.181, i64 18 }, { ptr, i64 } { ptr @tn.str.182, i64 7 }, { ptr, i64 } { ptr @tn.str.183, i64 6 }, { ptr, i64 } { ptr @tn.str.184, i64 8 }, { ptr, i64 } { ptr @tn.str.185, i64 8 }, { ptr, i64 } { ptr @tn.str.186, i64 8 }, { ptr, i64 } { ptr @tn.str.187, i64 4 }, { ptr, i64 } { ptr @tn.str.188, i64 5 }, { ptr, i64 } { ptr @tn.str.189, i64 5 }, { ptr, i64 } { ptr @tn.str.190, i64 7 }, { ptr, i64 } { ptr @tn.str.191, i64 10 }, { ptr, i64 } { ptr @tn.str.192, i64 3 }, { ptr, i64 } { ptr @tn.str.193, i64 13 }, { ptr, i64 } { ptr @tn.str.194, i64 14 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 8 }, { ptr, i64 } { ptr @tn.str.197, i64 9 }, { ptr, i64 } { ptr @tn.str.198, i64 4 }, { ptr, i64 } { ptr @tn.str.199, i64 9 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 6 }, { ptr, i64 } { ptr @tn.str.202, i64 5 }, { ptr, i64 } { ptr @tn.str.203, i64 6 }, { ptr, i64 } { ptr @tn.str.204, i64 8 }, { ptr, i64 } { ptr @tn.str.205, i64 6 }, { ptr, i64 } { ptr @tn.str.206, i64 9 }, { ptr, i64 } { ptr @tn.str.207, i64 7 }, { ptr, i64 } { ptr @tn.str.208, i64 4 }, { ptr, i64 } { ptr @tn.str.209, i64 4 }, { ptr, i64 } { ptr @tn.str.210, i64 5 }, { ptr, i64 } { ptr @tn.str.211, i64 16 }, { ptr, i64 } { ptr @tn.str.212, i64 14 }, { ptr, i64 } { ptr @tn.str.213, i64 21 }, { ptr, i64 } { ptr @tn.str.214, i64 6 }, { ptr, i64 } { ptr @tn.str.215, i64 7 }, { ptr, i64 } { ptr @tn.str.216, i64 24 }, { ptr, i64 } { ptr @tn.str.217, i64 23 }, { ptr, i64 } { ptr @tn.str.218, i64 15 }, { ptr, i64 } { ptr @tn.str.219, i64 12 }, { ptr, i64 } { ptr @tn.str.220, i64 12 }, { ptr, i64 } { ptr @tn.str.221, i64 10 }, { ptr, i64 } { ptr @tn.str.222, i64 4 }, { ptr, i64 } { ptr @tn.str.223, i64 8 }, { ptr, i64 } { ptr @tn.str.224, i64 8 }, { ptr, i64 } { ptr @tn.str.225, i64 10 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 9 }, { ptr, i64 } { ptr @tn.str.228, i64 4 }, { ptr, i64 } { ptr @tn.str.229, i64 13 }, { ptr, i64 } { ptr @tn.str.230, i64 6 }, { ptr, i64 } { ptr @tn.str.231, i64 7 }, { ptr, i64 } { ptr @tn.str.232, i64 18 }, { ptr, i64 } { ptr @tn.str.233, i64 9 }, { ptr, i64 } { ptr @tn.str.234, i64 5 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 6 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 1 }, { ptr, i64 } { ptr @tn.str.242, i64 1 }, { ptr, i64 } { ptr @tn.str.243, i64 12 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 2 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 5 }, { ptr, i64 } { ptr @tn.str.248, i64 4 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 5 }, { ptr, i64 } { ptr @tn.str.253, i64 7 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 16 }, { ptr, i64 } { ptr @tn.str.256, i64 10 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 11 }, { ptr, i64 } { ptr @tn.str.259, i64 14 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 8 }, { ptr, i64 } { ptr @tn.str.264, i64 10 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 9 }, { ptr, i64 } { ptr @tn.str.267, i64 6 }, { ptr, i64 } { ptr @tn.str.268, i64 16 }, { ptr, i64 } { ptr @tn.str.269, i64 13 }, { ptr, i64 } { ptr @tn.str.270, i64 14 }, { ptr, i64 } { ptr @tn.str.271, i64 7 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 5 }, { ptr, i64 } { ptr @tn.str.276, i64 11 }, { ptr, i64 } { ptr @tn.str.277, i64 10 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 12 }, { ptr, i64 } { ptr @tn.str.280, i64 7 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 10 }, { ptr, i64 } { ptr @tn.str.283, i64 19 }, { ptr, i64 } { ptr @tn.str.284, i64 6 }, { ptr, i64 } { ptr @tn.str.285, i64 4 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 9 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 10 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 13 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 3 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 7 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 6 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 15 }, { ptr, i64 } { ptr @tn.str.310, i64 8 }] @str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.315 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.316 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.317 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.318 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.319 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.320 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.324 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.325 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.326 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.327 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.328 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.329 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.315 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.316 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.317 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.318 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.319 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.320 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.321 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.322 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.323 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.324 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.325 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.326 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.327 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.328 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.329 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.330 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.331 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @frame.str = private unnamed_addr constant [35 x i8] c"1006-errors-inferred-error-sets.sx\00" -@frame.str.330 = private unnamed_addr constant [5 x i8] c"leaf\00" -@frame.str.331 = private unnamed_addr constant [34 x i8] c" if n < 0 { raise error.Foo; }\00" -@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 15, i32 16, { ptr, i64 } { ptr @frame.str.330, i64 4 }, { ptr, i64 } { ptr @frame.str.331, i64 33 } } -@frame.str.332 = private unnamed_addr constant [4 x i8] c"mid\00" -@frame.str.333 = private unnamed_addr constant [17 x i8] c" try leaf(n);\00" -@trace.frame.334 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 22, i32 5, { ptr, i64 } { ptr @frame.str.332, i64 3 }, { ptr, i64 } { ptr @frame.str.333, i64 16 } } -@frame.str.335 = private unnamed_addr constant [37 x i8] c" if n == 100 { raise error.Bar; }\00" -@trace.frame.336 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 23, i32 19, { ptr, i64 } { ptr @frame.str.332, i64 3 }, { ptr, i64 } { ptr @frame.str.335, i64 36 } } -@frame.str.337 = private unnamed_addr constant [4 x i8] c"run\00" -@frame.str.338 = private unnamed_addr constant [16 x i8] c" try mid(n);\00" -@trace.frame.339 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 29, i32 5, { ptr, i64 } { ptr @frame.str.337, i64 3 }, { ptr, i64 } { ptr @frame.str.338, i64 15 } } -@str.340 = private unnamed_addr constant [21 x i8] c"inferred result: {}\0A\00", align 1 -@str.341 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@frame.str.332 = private unnamed_addr constant [5 x i8] c"leaf\00" +@frame.str.333 = private unnamed_addr constant [34 x i8] c" if n < 0 { raise error.Foo; }\00" +@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 15, i32 16, { ptr, i64 } { ptr @frame.str.332, i64 4 }, { ptr, i64 } { ptr @frame.str.333, i64 33 } } +@frame.str.334 = private unnamed_addr constant [4 x i8] c"mid\00" +@frame.str.335 = private unnamed_addr constant [17 x i8] c" try leaf(n);\00" +@trace.frame.336 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 22, i32 5, { ptr, i64 } { ptr @frame.str.334, i64 3 }, { ptr, i64 } { ptr @frame.str.335, i64 16 } } +@frame.str.337 = private unnamed_addr constant [37 x i8] c" if n == 100 { raise error.Bar; }\00" +@trace.frame.338 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 23, i32 19, { ptr, i64 } { ptr @frame.str.334, i64 3 }, { ptr, i64 } { ptr @frame.str.337, i64 36 } } +@frame.str.339 = private unnamed_addr constant [4 x i8] c"run\00" +@frame.str.340 = private unnamed_addr constant [16 x i8] c" try mid(n);\00" +@trace.frame.341 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 34 }, i32 29, i32 5, { ptr, i64 } { ptr @frame.str.339, i64 3 }, { ptr, i64 } { ptr @frame.str.340, i64 15 } } @str.342 = private unnamed_addr constant [21 x i8] c"inferred result: {}\0A\00", align 1 -@str.343 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.344 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.345 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.346 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.343 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.344 = private unnamed_addr constant [21 x i8] c"inferred result: {}\0A\00", align 1 +@str.345 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.346 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.347 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.348 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.347 = private constant [5 x i8] c"line\00" -@fld.str.348 = private constant [4 x i8] c"col\00" -@fld.str.349 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.347, i64 4 }, { ptr, i64 } { ptr @fld.str.348, i64 3 }, { ptr, i64 } { ptr @fld.str.349, i64 4 }] -@str.350 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.351 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.352 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.353 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.355 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.357 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.361 = private constant [12 x i8] c"alloc_count\00" -@field_names.362 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 11 }] -@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.364 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.365 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.366 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.367 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.368 = private constant [5 x i8] c"next\00" -@fld.str.369 = private constant [4 x i8] c"cap\00" -@field_names.370 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 4 }, { ptr, i64 } { ptr @fld.str.369, i64 3 }] -@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.372 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.373 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.374 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.375 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.376 = private constant [4 x i8] c"ctx\00" -@fld.str.377 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.378 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.379 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.376, i64 3 }, { ptr, i64 } { ptr @fld.str.377, i64 11 }, { ptr, i64 } { ptr @fld.str.378, i64 13 }] -@str.380 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.381 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.382 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.383 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.384 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.385 = private constant [6 x i8] c"first\00" -@fld.str.386 = private constant [10 x i8] c"end_index\00" -@fld.str.387 = private constant [7 x i8] c"parent\00" -@field_names.388 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.385, i64 5 }, { ptr, i64 } { ptr @fld.str.386, i64 9 }, { ptr, i64 } { ptr @fld.str.387, i64 6 }] -@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.390 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.394 = private constant [4 x i8] c"buf\00" -@fld.str.395 = private constant [4 x i8] c"len\00" -@fld.str.396 = private constant [4 x i8] c"pos\00" -@field_names.397 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 3 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }, { ptr, i64 } { ptr @fld.str.396, i64 3 }] -@str.398 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.399 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.400 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.401 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.402 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.403 = private constant [7 x i8] c"parent\00" -@fld.str.404 = private constant [12 x i8] c"alloc_count\00" -@fld.str.405 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.406 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.407 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.403, i64 6 }, { ptr, i64 } { ptr @fld.str.404, i64 11 }, { ptr, i64 } { ptr @fld.str.405, i64 13 }, { ptr, i64 } { ptr @fld.str.406, i64 17 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [10 x i8] c"allocator\00" -@fld.str.414 = private constant [5 x i8] c"data\00" -@field_names.415 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 9 }, { ptr, i64 } { ptr @fld.str.414, i64 4 }] -@str.416 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.417 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.418 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.420 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.421 = private constant [3 x i8] c"fd\00" -@field_names.422 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 2 }] -@str.423 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.424 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.425 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.426 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.427 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.428 = private constant [5 x i8] c"file\00" -@fld.str.429 = private constant [5 x i8] c"line\00" -@fld.str.430 = private constant [4 x i8] c"col\00" -@fld.str.431 = private constant [5 x i8] c"func\00" -@fld.str.432 = private constant [10 x i8] c"line_text\00" -@field_names.433 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.428, i64 4 }, { ptr, i64 } { ptr @fld.str.429, i64 4 }, { ptr, i64 } { ptr @fld.str.430, i64 3 }, { ptr, i64 } { ptr @fld.str.431, i64 4 }, { ptr, i64 } { ptr @fld.str.432, i64 9 }] -@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.435 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.436 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.438 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.439 = private constant [10 x i8] c"exit_code\00" -@fld.str.440 = private constant [7 x i8] c"stdout\00" -@field_names.441 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 9 }, { ptr, i64 } { ptr @fld.str.440, i64 6 }] -@str.442 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.443 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.444 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.445 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.446 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.447 = private constant [8 x i8] c"sin_len\00" -@fld.str.448 = private constant [11 x i8] c"sin_family\00" -@fld.str.449 = private constant [9 x i8] c"sin_port\00" -@fld.str.450 = private constant [9 x i8] c"sin_addr\00" -@fld.str.451 = private constant [9 x i8] c"sin_zero\00" -@field_names.452 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.447, i64 7 }, { ptr, i64 } { ptr @fld.str.448, i64 10 }, { ptr, i64 } { ptr @fld.str.449, i64 8 }, { ptr, i64 } { ptr @fld.str.450, i64 8 }, { ptr, i64 } { ptr @fld.str.451, i64 8 }] -@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.454 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.458 = private constant [6 x i8] c"items\00" -@fld.str.459 = private constant [4 x i8] c"len\00" -@fld.str.460 = private constant [4 x i8] c"cap\00" -@field_names.461 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 5 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }, { ptr, i64 } { ptr @fld.str.460, i64 3 }] -@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.463 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.467 = private constant [6 x i8] c"items\00" -@fld.str.468 = private constant [4 x i8] c"len\00" -@fld.str.469 = private constant [4 x i8] c"cap\00" -@field_names.470 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 5 }, { ptr, i64 } { ptr @fld.str.468, i64 3 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }] -@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.472 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.476 = private constant [4 x i8] c"key\00" -@fld.str.477 = private constant [4 x i8] c"val\00" -@field_names.478 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 3 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [4 x i8] c"dst\00" -@fld.str.485 = private constant [4 x i8] c"pos\00" -@fld.str.486 = private constant [5 x i8] c"file\00" -@field_names.487 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 3 }, { ptr, i64 } { ptr @fld.str.486, i64 4 }] -@str.488 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.489 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.490 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.492 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.493 = private constant [4 x i8] c"src\00" -@fld.str.494 = private constant [4 x i8] c"pos\00" -@fld.str.495 = private constant [6 x i8] c"alloc\00" -@field_names.496 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.493, i64 3 }, { ptr, i64 } { ptr @fld.str.494, i64 3 }, { ptr, i64 } { ptr @fld.str.495, i64 5 }] -@str.497 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.498 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.499 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.501 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.502 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.504 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.505 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.506 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.507 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.508 = private constant [5 x i8] c"name\00" -@fld.str.509 = private constant [12 x i8] c"takes_value\00" -@fld.str.510 = private constant [9 x i8] c"required\00" -@field_names.511 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.508, i64 4 }, { ptr, i64 } { ptr @fld.str.509, i64 11 }, { ptr, i64 } { ptr @fld.str.510, i64 8 }] -@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.513 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.514 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.515 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.516 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.517 = private constant [6 x i8] c"group\00" -@fld.str.518 = private constant [8 x i8] c"command\00" -@fld.str.519 = private constant [6 x i8] c"flags\00" -@field_names.520 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.517, i64 5 }, { ptr, i64 } { ptr @fld.str.518, i64 7 }, { ptr, i64 } { ptr @fld.str.519, i64 5 }] -@str.521 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.522 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.523 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.524 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.525 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.526 = private constant [4 x i8] c"set\00" -@fld.str.527 = private constant [6 x i8] c"value\00" -@field_names.528 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.526, i64 3 }, { ptr, i64 } { ptr @fld.str.527, i64 5 }] -@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.530 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.531 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.532 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.533 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.534 = private constant [6 x i8] c"index\00" -@fld.str.535 = private constant [6 x i8] c"token\00" -@field_names.536 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 5 }, { ptr, i64 } { ptr @fld.str.535, i64 5 }] -@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.538 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.542 = private constant [6 x i8] c"group\00" -@fld.str.543 = private constant [8 x i8] c"command\00" -@fld.str.544 = private constant [10 x i8] c"cmd_index\00" -@fld.str.545 = private constant [5 x i8] c"json\00" -@fld.str.546 = private constant [5 x i8] c"rest\00" -@fld.str.547 = private constant [5 x i8] c"spec\00" -@fld.str.548 = private constant [7 x i8] c"values\00" -@field_names.549 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 5 }, { ptr, i64 } { ptr @fld.str.543, i64 7 }, { ptr, i64 } { ptr @fld.str.544, i64 9 }, { ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 4 }, { ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 6 }] -@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.551 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.553 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.554 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.555 = private constant [2 x i8] c"h\00" -@fld.str.556 = private constant [4 x i8] c"buf\00" -@fld.str.557 = private constant [8 x i8] c"buf_len\00" -@fld.str.558 = private constant [10 x i8] c"total_len\00" -@field_names.559 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 1 }, { ptr, i64 } { ptr @fld.str.556, i64 3 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 9 }] -@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.562 = private constant [5 x i8] c"read\00" -@fld.str.563 = private constant [6 x i8] c"write\00" -@fld.str.564 = private constant [7 x i8] c"append\00" -@fld.str.565 = private constant [11 x i8] c"read_write\00" -@field_names.566 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.562, i64 4 }, { ptr, i64 } { ptr @fld.str.563, i64 5 }, { ptr, i64 } { ptr @fld.str.564, i64 6 }, { ptr, i64 } { ptr @fld.str.565, i64 10 }] -@str.567 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.570 = private constant [4 x i8] c"set\00" -@fld.str.571 = private constant [8 x i8] c"current\00" -@fld.str.572 = private constant [4 x i8] c"end\00" -@field_names.573 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 7 }, { ptr, i64 } { ptr @fld.str.572, i64 3 }] -@str.574 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.575 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.577 = private constant [6 x i8] c"null_\00" -@fld.str.578 = private constant [6 x i8] c"bool_\00" -@fld.str.579 = private constant [5 x i8] c"int_\00" -@fld.str.580 = private constant [4 x i8] c"str\00" -@fld.str.581 = private constant [6 x i8] c"array\00" -@fld.str.582 = private constant [7 x i8] c"object\00" -@field_names.583 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 3 }, { ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 6 }] -@str.584 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.585 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.586 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.587 = private constant [6 x i8] c"macos\00" -@fld.str.588 = private constant [6 x i8] c"linux\00" -@fld.str.589 = private constant [8 x i8] c"windows\00" -@fld.str.590 = private constant [5 x i8] c"wasm\00" -@fld.str.591 = private constant [4 x i8] c"ios\00" -@fld.str.592 = private constant [8 x i8] c"android\00" -@fld.str.593 = private constant [8 x i8] c"unknown\00" -@field_names.594 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 5 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 4 }, { ptr, i64 } { ptr @fld.str.591, i64 3 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }] -@str.595 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.596 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.597 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.598 = private constant [8 x i8] c"aarch64\00" -@fld.str.599 = private constant [7 x i8] c"x86_64\00" -@fld.str.600 = private constant [7 x i8] c"wasm32\00" -@fld.str.601 = private constant [7 x i8] c"wasm64\00" -@fld.str.602 = private constant [8 x i8] c"unknown\00" -@field_names.603 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.598, i64 7 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 6 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 7 }] -@str.604 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.633 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.634 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.635 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.636 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.638 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.640 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.643 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.649 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.652 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.655 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.658 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.661 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.664 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.667 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.673 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.679 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.682 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.685 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.688 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.691 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.694 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.700 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.703 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.706 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.709 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.349 = private constant [5 x i8] c"line\00" +@fld.str.350 = private constant [4 x i8] c"col\00" +@fld.str.351 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.349, i64 4 }, { ptr, i64 } { ptr @fld.str.350, i64 3 }, { ptr, i64 } { ptr @fld.str.351, i64 4 }] +@str.352 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.353 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.354 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.355 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.356 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.357 = private constant [4 x i8] c"ctx\00" +@fld.str.358 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.359 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.360 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.357, i64 3 }, { ptr, i64 } { ptr @fld.str.358, i64 11 }, { ptr, i64 } { ptr @fld.str.359, i64 13 }] +@str.361 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.362 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.363 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.364 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.366 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.367 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.368 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.369 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.370 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.372 = private constant [12 x i8] c"alloc_count\00" +@field_names.373 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.372, i64 11 }] +@str.374 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.375 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.376 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.377 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.378 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.379 = private constant [5 x i8] c"next\00" +@fld.str.380 = private constant [4 x i8] c"cap\00" +@field_names.381 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.379, i64 4 }, { ptr, i64 } { ptr @fld.str.380, i64 3 }] +@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.383 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.385 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.386 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.387 = private constant [6 x i8] c"first\00" +@fld.str.388 = private constant [10 x i8] c"end_index\00" +@fld.str.389 = private constant [7 x i8] c"parent\00" +@field_names.390 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.387, i64 5 }, { ptr, i64 } { ptr @fld.str.388, i64 9 }, { ptr, i64 } { ptr @fld.str.389, i64 6 }] +@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.392 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.396 = private constant [4 x i8] c"buf\00" +@fld.str.397 = private constant [4 x i8] c"len\00" +@fld.str.398 = private constant [4 x i8] c"pos\00" +@field_names.399 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 3 }, { ptr, i64 } { ptr @fld.str.397, i64 3 }, { ptr, i64 } { ptr @fld.str.398, i64 3 }] +@str.400 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.401 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.402 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.403 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.404 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.405 = private constant [7 x i8] c"parent\00" +@fld.str.406 = private constant [12 x i8] c"alloc_count\00" +@fld.str.407 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.408 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.409 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.405, i64 6 }, { ptr, i64 } { ptr @fld.str.406, i64 11 }, { ptr, i64 } { ptr @fld.str.407, i64 13 }, { ptr, i64 } { ptr @fld.str.408, i64 17 }] +@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.411 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.415 = private constant [10 x i8] c"allocator\00" +@fld.str.416 = private constant [5 x i8] c"data\00" +@field_names.417 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 9 }, { ptr, i64 } { ptr @fld.str.416, i64 4 }] +@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.419 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.423 = private constant [3 x i8] c"fd\00" +@field_names.424 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 2 }] +@str.425 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.426 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.427 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.428 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.429 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.430 = private constant [5 x i8] c"file\00" +@fld.str.431 = private constant [5 x i8] c"line\00" +@fld.str.432 = private constant [4 x i8] c"col\00" +@fld.str.433 = private constant [5 x i8] c"func\00" +@fld.str.434 = private constant [10 x i8] c"line_text\00" +@field_names.435 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.430, i64 4 }, { ptr, i64 } { ptr @fld.str.431, i64 4 }, { ptr, i64 } { ptr @fld.str.432, i64 3 }, { ptr, i64 } { ptr @fld.str.433, i64 4 }, { ptr, i64 } { ptr @fld.str.434, i64 9 }] +@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.437 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.441 = private constant [10 x i8] c"exit_code\00" +@fld.str.442 = private constant [7 x i8] c"stdout\00" +@field_names.443 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 9 }, { ptr, i64 } { ptr @fld.str.442, i64 6 }] +@str.444 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.445 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.446 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.447 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.448 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.449 = private constant [8 x i8] c"sin_len\00" +@fld.str.450 = private constant [11 x i8] c"sin_family\00" +@fld.str.451 = private constant [9 x i8] c"sin_port\00" +@fld.str.452 = private constant [9 x i8] c"sin_addr\00" +@fld.str.453 = private constant [9 x i8] c"sin_zero\00" +@field_names.454 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.449, i64 7 }, { ptr, i64 } { ptr @fld.str.450, i64 10 }, { ptr, i64 } { ptr @fld.str.451, i64 8 }, { ptr, i64 } { ptr @fld.str.452, i64 8 }, { ptr, i64 } { ptr @fld.str.453, i64 8 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.460 = private constant [6 x i8] c"items\00" +@fld.str.461 = private constant [4 x i8] c"len\00" +@fld.str.462 = private constant [4 x i8] c"cap\00" +@field_names.463 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 5 }, { ptr, i64 } { ptr @fld.str.461, i64 3 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.466 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.468 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.469 = private constant [6 x i8] c"items\00" +@fld.str.470 = private constant [4 x i8] c"len\00" +@fld.str.471 = private constant [4 x i8] c"cap\00" +@field_names.472 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 5 }, { ptr, i64 } { ptr @fld.str.470, i64 3 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }] +@str.473 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.474 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.477 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.478 = private constant [4 x i8] c"key\00" +@fld.str.479 = private constant [4 x i8] c"val\00" +@field_names.480 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.478, i64 3 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [4 x i8] c"dst\00" +@fld.str.487 = private constant [4 x i8] c"pos\00" +@fld.str.488 = private constant [5 x i8] c"file\00" +@field_names.489 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 3 }, { ptr, i64 } { ptr @fld.str.487, i64 3 }, { ptr, i64 } { ptr @fld.str.488, i64 4 }] +@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.491 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.495 = private constant [4 x i8] c"src\00" +@fld.str.496 = private constant [4 x i8] c"pos\00" +@fld.str.497 = private constant [6 x i8] c"alloc\00" +@field_names.498 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.495, i64 3 }, { ptr, i64 } { ptr @fld.str.496, i64 3 }, { ptr, i64 } { ptr @fld.str.497, i64 5 }] +@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.500 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.501 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.503 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.504 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.505 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.506 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.507 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.508 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.509 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.510 = private constant [5 x i8] c"name\00" +@fld.str.511 = private constant [12 x i8] c"takes_value\00" +@fld.str.512 = private constant [9 x i8] c"required\00" +@field_names.513 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.510, i64 4 }, { ptr, i64 } { ptr @fld.str.511, i64 11 }, { ptr, i64 } { ptr @fld.str.512, i64 8 }] +@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.515 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.516 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.517 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.518 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.519 = private constant [6 x i8] c"group\00" +@fld.str.520 = private constant [8 x i8] c"command\00" +@fld.str.521 = private constant [6 x i8] c"flags\00" +@field_names.522 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 5 }, { ptr, i64 } { ptr @fld.str.520, i64 7 }, { ptr, i64 } { ptr @fld.str.521, i64 5 }] +@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.524 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.525 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.526 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.527 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.528 = private constant [4 x i8] c"set\00" +@fld.str.529 = private constant [6 x i8] c"value\00" +@field_names.530 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.528, i64 3 }, { ptr, i64 } { ptr @fld.str.529, i64 5 }] +@str.531 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.532 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.533 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.534 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.535 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.536 = private constant [6 x i8] c"index\00" +@fld.str.537 = private constant [6 x i8] c"token\00" +@field_names.538 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.536, i64 5 }, { ptr, i64 } { ptr @fld.str.537, i64 5 }] +@str.539 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.540 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.541 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.542 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.543 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.544 = private constant [6 x i8] c"group\00" +@fld.str.545 = private constant [8 x i8] c"command\00" +@fld.str.546 = private constant [10 x i8] c"cmd_index\00" +@fld.str.547 = private constant [5 x i8] c"json\00" +@fld.str.548 = private constant [5 x i8] c"rest\00" +@fld.str.549 = private constant [5 x i8] c"spec\00" +@fld.str.550 = private constant [7 x i8] c"values\00" +@field_names.551 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.544, i64 5 }, { ptr, i64 } { ptr @fld.str.545, i64 7 }, { ptr, i64 } { ptr @fld.str.546, i64 9 }, { ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 4 }, { ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 6 }] +@str.552 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.553 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.555 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.556 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.557 = private constant [2 x i8] c"h\00" +@fld.str.558 = private constant [4 x i8] c"buf\00" +@fld.str.559 = private constant [8 x i8] c"buf_len\00" +@fld.str.560 = private constant [10 x i8] c"total_len\00" +@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 1 }, { ptr, i64 } { ptr @fld.str.558, i64 3 }, { ptr, i64 } { ptr @fld.str.559, i64 7 }, { ptr, i64 } { ptr @fld.str.560, i64 9 }] +@str.562 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.564 = private constant [5 x i8] c"read\00" +@fld.str.565 = private constant [6 x i8] c"write\00" +@fld.str.566 = private constant [7 x i8] c"append\00" +@fld.str.567 = private constant [11 x i8] c"read_write\00" +@field_names.568 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 4 }, { ptr, i64 } { ptr @fld.str.565, i64 5 }, { ptr, i64 } { ptr @fld.str.566, i64 6 }, { ptr, i64 } { ptr @fld.str.567, i64 10 }] +@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.572 = private constant [4 x i8] c"set\00" +@fld.str.573 = private constant [8 x i8] c"current\00" +@fld.str.574 = private constant [4 x i8] c"end\00" +@field_names.575 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 3 }, { ptr, i64 } { ptr @fld.str.573, i64 7 }, { ptr, i64 } { ptr @fld.str.574, i64 3 }] +@str.576 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.577 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.579 = private constant [6 x i8] c"null_\00" +@fld.str.580 = private constant [6 x i8] c"bool_\00" +@fld.str.581 = private constant [5 x i8] c"int_\00" +@fld.str.582 = private constant [4 x i8] c"str\00" +@fld.str.583 = private constant [6 x i8] c"array\00" +@fld.str.584 = private constant [7 x i8] c"object\00" +@field_names.585 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 4 }, { ptr, i64 } { ptr @fld.str.582, i64 3 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 6 }] +@str.586 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.587 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.588 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.589 = private constant [6 x i8] c"macos\00" +@fld.str.590 = private constant [6 x i8] c"linux\00" +@fld.str.591 = private constant [8 x i8] c"windows\00" +@fld.str.592 = private constant [5 x i8] c"wasm\00" +@fld.str.593 = private constant [4 x i8] c"ios\00" +@fld.str.594 = private constant [8 x i8] c"android\00" +@fld.str.595 = private constant [8 x i8] c"unknown\00" +@field_names.596 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 5 }, { ptr, i64 } { ptr @fld.str.590, i64 5 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 3 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 7 }] +@str.597 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.598 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.599 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.600 = private constant [8 x i8] c"aarch64\00" +@fld.str.601 = private constant [7 x i8] c"x86_64\00" +@fld.str.602 = private constant [7 x i8] c"wasm32\00" +@fld.str.603 = private constant [7 x i8] c"wasm64\00" +@fld.str.604 = private constant [8 x i8] c"unknown\00" +@field_names.605 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.600, i64 7 }, { ptr, i64 } { ptr @fld.str.601, i64 6 }, { ptr, i64 } { ptr @fld.str.602, i64 6 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 7 }] +@str.606 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.610 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.614 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.616 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.620 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.622 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.626 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.628 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.631 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.634 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.635 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.636 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.637 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.638 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.640 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.641 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.642 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.643 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.644 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.645 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.646 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.647 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.649 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.650 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.651 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.652 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.653 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.654 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.655 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.656 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.657 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.658 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.659 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.660 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.661 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.662 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.663 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.664 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.665 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.666 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.667 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.668 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.669 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.670 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.671 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.673 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.674 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.675 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.676 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.677 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.679 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.680 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.681 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.682 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.683 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.684 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.685 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.686 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.687 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.688 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.689 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.690 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.691 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.692 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.693 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.694 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.695 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.696 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.697 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.698 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.700 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.701 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.702 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.703 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.704 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.705 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.706 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.707 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.708 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.709 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.710 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.711 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.712 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -632,6 +632,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -851,7 +854,7 @@ entry: br i1 %icmp, label %if.then.68, label %if.merge.69 if.then.68: ; preds = %entry - ret { ptr, i64 } { ptr @str.126, i64 1 } + ret { ptr, i64 } { ptr @str.128, i64 1 } if.merge.69: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -978,7 +981,7 @@ if.else.91: ; preds = %entry br label %if.merge.92 if.merge.92: ; preds = %if.else.91, %if.then.90 - %bp = phi { ptr, i64 } [ { ptr @str.127, i64 4 }, %if.then.90 ], [ { ptr @str.128, i64 5 }, %if.else.91 ] + %bp = phi { ptr, i64 } [ { ptr @str.129, i64 4 }, %if.then.90 ], [ { ptr @str.130, i64 5 }, %if.else.91 ] ret { ptr, i64 } %bp } @@ -1312,7 +1315,7 @@ entry: br i1 %icmp, label %if.then.381, label %if.merge.382 if.then.381: ; preds = %entry - ret { ptr, i64 } { ptr @str.129, i64 1 } + ret { ptr, i64 } { ptr @str.131, i64 1 } if.merge.382: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1462,7 +1465,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.130, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1488,9 +1491,9 @@ entry: i64 11, label %match.arm.54 i64 19, label %match.arm.55 i64 20, label %match.arm.55 - i64 22, label %match.arm.55 - i64 24, label %match.arm.55 - i64 26, label %match.arm.55 + i64 21, label %match.arm.55 + i64 23, label %match.arm.55 + i64 25, label %match.arm.55 i64 27, label %match.arm.55 i64 30, label %match.arm.55 i64 32, label %match.arm.55 @@ -1533,9 +1536,9 @@ entry: i64 85, label %match.arm.60 i64 99, label %match.arm.60 i64 18, label %match.arm.61 - i64 21, label %match.arm.61 - i64 23, label %match.arm.61 - i64 25, label %match.arm.61 + i64 22, label %match.arm.61 + i64 24, label %match.arm.61 + i64 26, label %match.arm.61 i64 28, label %match.arm.61 i64 29, label %match.arm.61 i64 31, label %match.arm.61 @@ -1575,7 +1578,7 @@ match.merge.49: ; preds = %dispatch.merge.484, ret { ptr, i64 } %loadN match.arm.50: ; preds = %entry - store { ptr, i64 } { ptr @str.131, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, i64 0 }, ptr %allocaN, align 8 br label %match.merge.49 match.arm.51: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1619,9 +1622,9 @@ match.arm.55: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.107 [ i64 19, label %dispatch.case.108 i64 20, label %dispatch.case.109 - i64 22, label %dispatch.case.110 - i64 24, label %dispatch.case.111 - i64 26, label %dispatch.case.112 + i64 21, label %dispatch.case.110 + i64 23, label %dispatch.case.111 + i64 25, label %dispatch.case.112 i64 27, label %dispatch.case.113 i64 30, label %dispatch.case.114 i64 32, label %dispatch.case.115 @@ -1702,9 +1705,9 @@ match.arm.61: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.346 [ i64 18, label %dispatch.case.347 - i64 21, label %dispatch.case.348 - i64 23, label %dispatch.case.349 - i64 25, label %dispatch.case.350 + i64 22, label %dispatch.case.348 + i64 24, label %dispatch.case.349 + i64 26, label %dispatch.case.350 i64 28, label %dispatch.case.351 i64 29, label %dispatch.case.352 i64 31, label %dispatch.case.353 @@ -1802,7 +1805,7 @@ dispatch.merge.106: ; preds = %dispatch.case.132, br label %match.merge.49 dispatch.default.107: ; preds = %match.arm.55 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.108: ; preds = %match.arm.55 @@ -1816,32 +1819,32 @@ dispatch.case.108: ; preds = %match.arm.55 dispatch.case.109: ; preds = %match.arm.55 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.110: ; preds = %match.arm.55 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.111: ; preds = %match.arm.55 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.112: ; preds = %match.arm.55 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 @@ -2011,7 +2014,7 @@ dispatch.merge.258: ; preds = %dispatch.case.264, br label %match.merge.49 dispatch.default.259: ; preds = %match.arm.56 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.258 dispatch.case.260: ; preds = %match.arm.56 @@ -2052,7 +2055,7 @@ dispatch.merge.275: ; preds = %dispatch.case.282, br label %match.merge.49 dispatch.default.276: ; preds = %match.arm.59 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.275 dispatch.case.277: ; preds = %match.arm.59 @@ -2109,7 +2112,7 @@ dispatch.merge.313: ; preds = %dispatch.case.319, br label %match.merge.49 dispatch.default.314: ; preds = %match.arm.60 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.313 dispatch.case.315: ; preds = %match.arm.60 @@ -2158,7 +2161,7 @@ dispatch.merge.345: ; preds = %dispatch.case.377, br label %match.merge.49 dispatch.default.346: ; preds = %match.arm.61 - store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.345 dispatch.case.347: ; preds = %match.arm.61 @@ -2384,7 +2387,7 @@ dispatch.merge.484: ; preds = %dispatch.case.489, br label %match.merge.49 dispatch.default.485: ; preds = %match.arm.62 - store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.484 dispatch.case.486: ; preds = %match.arm.62 @@ -2426,7 +2429,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.315, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2522,7 +2525,7 @@ if.merge.23: ; preds = %if.merge.37, %if.me if.then.24: ; preds = %if.then.21 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2530,7 +2533,7 @@ if.then.24: ; preds = %if.then.21 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2540,13 +2543,13 @@ if.then.24: ; preds = %if.then.21 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.25 if.merge.25: ; preds = %if.then.24, %if.then.21 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2554,7 +2557,7 @@ if.merge.25: ; preds = %if.then.24, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2568,7 +2571,7 @@ if.merge.25: ; preds = %if.then.24, %if.the if.then.35: ; preds = %if.else.22 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2576,7 +2579,7 @@ if.then.35: ; preds = %if.else.22 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2587,7 +2590,7 @@ if.then.35: ; preds = %if.else.22 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2644,7 +2647,7 @@ if.merge.43: ; preds = %if.merge.46, %if.el if.then.44: ; preds = %if.then.41 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2652,7 +2655,7 @@ if.then.44: ; preds = %if.then.41 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2663,7 +2666,7 @@ if.then.44: ; preds = %if.then.41 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2683,7 +2686,7 @@ if.merge.46: ; preds = %if.else.45, %if.the if.then.47: ; preds = %while.exit.14 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2691,7 +2694,7 @@ if.then.47: ; preds = %while.exit.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, 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 @@ -2702,7 +2705,7 @@ if.then.47: ; preds = %while.exit.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.48 @@ -2712,64 +2715,67 @@ if.merge.48: ; preds = %if.then.47, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2945,163 +2951,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3299,64 +3308,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3386,97 +3395,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3515,7 +3524,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @leaf(ptr %0, i32 %1) #0 { @@ -3561,7 +3570,7 @@ if.merge.5: ; preds = %try.ok.3 } ; Function Attrs: nounwind -define internal i32 @run.125(ptr %0, i32 %1) #0 { +define internal i32 @run.127(ptr %0, i32 %1) #0 { entry: %alloca = alloca i32, align 4 store i32 %1, ptr %alloca, align 4 @@ -3580,7 +3589,7 @@ try.ok.7: ; preds = %entry ; Function Attrs: nounwind define i32 @main() #0 { entry: - %call = call i32 @run.125(ptr @__sx_default_context, i32 -1) + %call = call i32 @run.127(ptr @__sx_default_context, i32 -1) %alloca = alloca i32, align 4 store i32 %call, ptr %alloca, align 4 %allocaN = alloca i32, align 4 @@ -3631,7 +3640,7 @@ entry: define internal void @print__ct_s5a624c50db282f36__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.340, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.342, i64 20 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3647,7 +3656,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.341, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.343, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 17) @@ -3675,7 +3684,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.342, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.344, i64 20 }) ret { ptr, i64 } %call } @@ -3686,7 +3695,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 15 }, { ptr, i64 } { ptr @str.344, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.345, i64 15 }, { ptr, i64 } { ptr @str.346, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3705,12 +3714,12 @@ while.body.134: ; preds = %while.hdr.133 while.exit.135: ; preds = %while.hdr.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 1 }) ret { ptr, i64 } %callN if.then.136: ; preds = %while.body.134 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.137 @@ -3722,7 +3731,7 @@ if.merge.137: ; preds = %if.then.136, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3775,20 +3784,20 @@ fv.case24: ; preds = %if.merge.137 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.351, i64 10 }, { ptr, i64 } { ptr @str.352, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.353, i64 9 }, { ptr, i64 } { ptr @str.354, 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.138 -while.hdr.138: ; preds = %if.merge.142, %entry +while.hdr.138: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.139, label %while.exit.140 while.body.139: ; preds = %while.hdr.138 @@ -3798,224 +3807,24 @@ while.body.139: ; preds = %while.hdr.138 while.exit.140: ; preds = %while.hdr.138 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 1 }) ret { ptr, i64 } %callN if.then.141: ; preds = %while.body.139 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.142 if.merge.142: ; preds = %if.then.141, %while.body.139 %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.355, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.360, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.138 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 3 }, { ptr, i64 } { ptr @str.358, 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.143 - -while.hdr.143: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.144, label %while.exit.145 - -while.body.144: ; preds = %while.hdr.143 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.146, label %if.merge.147 - -while.exit.145: ; preds = %while.hdr.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) - ret { ptr, i64 } %callN - -if.then.146: ; preds = %while.body.144 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.147 - -if.merge.147: ; preds = %if.then.146, %while.body.144 - %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.362, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.143 - -fv.default: ; preds = %if.merge.147 - br label %fv.merge - -fv.case: ; preds = %if.merge.147 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.364, i64 10 }, { ptr, i64 } { ptr @str.365, 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.148 - -while.hdr.148: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.149, label %while.exit.150 - -while.body.149: ; preds = %while.hdr.148 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.151, label %if.merge.152 - -while.exit.150: ; preds = %while.hdr.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 1 }) - ret { ptr, i64 } %callN - -if.then.151: ; preds = %while.body.149 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.152 - -if.merge.152: ; preds = %if.then.151, %while.body.149 - %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.370, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.148 - -fv.default: ; preds = %if.merge.152 - br label %fv.merge - -fv.case: ; preds = %if.merge.152 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.152 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.372, i64 9 }, { ptr, i64 } { ptr @str.373, 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.153 - -while.hdr.153: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.154, label %while.exit.155 - -while.body.154: ; preds = %while.hdr.153 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.156, label %if.merge.157 - -while.exit.155: ; preds = %while.hdr.153 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 1 }) - ret { ptr, i64 } %callN - -if.then.156: ; preds = %while.body.154 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.157 - -if.merge.157: ; preds = %if.then.156, %while.body.154 - %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.379, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, 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 @@ -4034,27 +3843,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.138 + +fv.default: ; preds = %if.merge.142 + br label %fv.merge + +fv.case: ; preds = %if.merge.142 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.142 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.142 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.362, i64 10 }, { ptr, i64 } { ptr @str.363, 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.143 + +while.hdr.143: ; preds = %if.merge.147, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.144, label %while.exit.145 + +while.body.144: ; preds = %while.hdr.143 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.146, label %if.merge.147 + +while.exit.145: ; preds = %while.hdr.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 1 }) + ret { ptr, i64 } %callN + +if.then.146: ; preds = %while.body.144 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.147 + +if.merge.147: ; preds = %if.then.146, %while.body.144 + %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.366, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.143 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.368, i64 3 }, { ptr, i64 } { ptr @str.369, 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.148 + +while.hdr.148: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.149, label %while.exit.150 + +while.body.149: ; preds = %while.hdr.148 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.151, label %if.merge.152 + +while.exit.150: ; preds = %while.hdr.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 1 }) + ret { ptr, i64 } %callN + +if.then.151: ; preds = %while.body.149 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.152 + +if.merge.152: ; preds = %if.then.151, %while.body.149 + %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.373, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.148 + +fv.default: ; preds = %if.merge.152 + br label %fv.merge + +fv.case: ; preds = %if.merge.152 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.375, i64 10 }, { ptr, i64 } { ptr @str.376, 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.153 + +while.hdr.153: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.154, label %while.exit.155 + +while.body.154: ; preds = %while.hdr.153 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.156, label %if.merge.157 + +while.exit.155: ; preds = %while.hdr.153 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 1 }) + ret { ptr, i64 } %callN + +if.then.156: ; preds = %while.body.154 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.157 + +if.merge.157: ; preds = %if.then.156, %while.body.154 + %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.381, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.153 fv.default: ; preds = %if.merge.157 br label %fv.merge fv.case: ; preds = %if.merge.157 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.157 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.157 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4064,7 +4073,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.381, i64 5 }, { ptr, i64 } { ptr @str.382, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 5 }, { ptr, i64 } { ptr @str.384, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4083,24 +4092,24 @@ while.body.159: ; preds = %while.hdr.158 while.exit.160: ; preds = %while.hdr.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 1 }) ret { ptr, i64 } %callN if.then.161: ; preds = %while.body.159 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.162 if.merge.162: ; preds = %if.then.161, %while.body.159 %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.388, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.390, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, 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 @@ -4127,7 +4136,7 @@ fv.default: ; preds = %if.merge.162 fv.case: ; preds = %if.merge.162 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.162 @@ -4139,7 +4148,7 @@ fv.case20: ; preds = %if.merge.162 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4148,7 +4157,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 8 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 8 }, { ptr, i64 } { ptr @str.393, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4167,24 +4176,24 @@ while.body.164: ; preds = %while.hdr.163 while.exit.165: ; preds = %while.hdr.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) ret { ptr, i64 } %callN if.then.166: ; preds = %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.167 if.merge.167: ; preds = %if.then.166, %while.body.164 %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.397, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.399, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, 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 @@ -4231,7 +4240,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 17 }, { ptr, i64 } { ptr @str.400, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.401, i64 17 }, { ptr, i64 } { ptr @str.402, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4250,24 +4259,24 @@ while.body.169: ; preds = %while.hdr.168 while.exit.170: ; preds = %while.hdr.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 1 }) ret { ptr, i64 } %callN if.then.171: ; preds = %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.172 if.merge.172: ; preds = %if.then.171, %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4296,7 +4305,7 @@ fv.case: ; preds = %if.merge.172 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.172 @@ -4321,7 +4330,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 7 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 7 }, { ptr, i64 } { ptr @str.412, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4340,24 +4349,24 @@ while.body.174: ; preds = %while.hdr.173 while.exit.175: ; preds = %while.hdr.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) ret { ptr, i64 } %callN if.then.176: ; preds = %while.body.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.177 if.merge.177: ; preds = %if.then.176, %while.body.174 %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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, 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 @@ -4384,7 +4393,7 @@ fv.case: ; preds = %if.merge.177 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.177 @@ -4399,7 +4408,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 4 }, { ptr, i64 } { ptr @str.418, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 4 }, { ptr, i64 } { ptr @str.420, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4418,24 +4427,24 @@ while.body.179: ; preds = %while.hdr.178 while.exit.180: ; preds = %while.hdr.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) ret { ptr, i64 } %callN if.then.181: ; preds = %while.body.179 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.182 if.merge.182: ; preds = %if.then.181, %while.body.179 %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.422, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.424, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4472,7 +4481,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.424, i64 10 }, { ptr, i64 } { ptr @str.425, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 10 }, { ptr, i64 } { ptr @str.427, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4491,24 +4500,24 @@ while.body.184: ; preds = %while.hdr.183 while.exit.185: ; preds = %while.hdr.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, i64 1 }) ret { ptr, i64 } %callN if.then.186: ; preds = %while.body.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.187 if.merge.187: ; preds = %if.then.186, %while.body.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.433, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4574,7 +4583,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 13 }, { ptr, i64 } { ptr @str.436, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 13 }, { ptr, i64 } { ptr @str.438, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4593,24 +4602,24 @@ while.body.189: ; preds = %while.hdr.188 while.exit.190: ; preds = %while.hdr.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) ret { ptr, i64 } %callN if.then.191: ; preds = %while.body.189 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.192 if.merge.192: ; preds = %if.then.191, %while.body.189 %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.441, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.443, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.444, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4652,7 +4661,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.443, i64 8 }, { ptr, i64 } { ptr @str.444, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 8 }, { ptr, i64 } { ptr @str.446, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4671,24 +4680,24 @@ while.body.194: ; preds = %while.hdr.193 while.exit.195: ; preds = %while.hdr.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 1 }) ret { ptr, i64 } %callN if.then.196: ; preds = %while.body.194 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.446, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.197 if.merge.197: ; preds = %if.then.196, %while.body.194 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4749,7 +4758,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 5 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 5 }, { ptr, i64 } { ptr @str.457, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4768,24 +4777,24 @@ while.body.199: ; preds = %while.hdr.198 while.exit.200: ; preds = %while.hdr.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) ret { ptr, i64 } %callN if.then.201: ; preds = %while.body.199 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.202 if.merge.202: ; preds = %if.then.201, %while.body.199 %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.461, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.463, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, 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 @@ -4831,7 +4840,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 6 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 6 }, { ptr, i64 } { ptr @str.466, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4850,24 +4859,24 @@ while.body.204: ; preds = %while.hdr.203 while.exit.205: ; preds = %while.hdr.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 1 }) ret { ptr, i64 } %callN if.then.206: ; preds = %while.body.204 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.207 if.merge.207: ; preds = %if.then.206, %while.body.204 %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.470, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.472, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, 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 @@ -4915,7 +4924,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 6 }, { ptr, i64 } { ptr @str.473, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.474, i64 6 }, { ptr, i64 } { ptr @str.475, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4934,24 +4943,24 @@ while.body.209: ; preds = %while.hdr.208 while.exit.210: ; preds = %while.hdr.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 1 }) ret { ptr, i64 } %callN if.then.211: ; preds = %while.body.209 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.212 if.merge.212: ; preds = %if.then.211, %while.body.209 %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.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4995,7 +5004,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 4 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 4 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5014,24 +5023,24 @@ while.body.214: ; preds = %while.hdr.213 while.exit.215: ; preds = %while.hdr.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.216: ; preds = %while.body.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.217 if.merge.217: ; preds = %if.then.216, %while.body.214 %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.487, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.489, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5081,7 +5090,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 6 }, { ptr, i64 } { ptr @str.490, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 6 }, { ptr, i64 } { ptr @str.492, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5100,24 +5109,24 @@ while.body.219: ; preds = %while.hdr.218 while.exit.220: ; preds = %while.hdr.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) ret { ptr, i64 } %callN if.then.221: ; preds = %while.body.219 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.222 if.merge.222: ; preds = %if.then.221, %while.body.219 %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.496, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.498, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5157,7 +5166,7 @@ fv.case20: ; preds = %if.merge.222 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5166,7 +5175,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.498, i64 12 }, { ptr, i64 } { ptr @str.499, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 12 }, { ptr, i64 } { ptr @str.501, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5185,24 +5194,24 @@ while.body.224: ; preds = %while.hdr.223 while.exit.225: ; preds = %while.hdr.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 1 }) ret { ptr, i64 } %callN if.then.226: ; preds = %while.body.224 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.227 if.merge.227: ; preds = %if.then.226, %while.body.224 %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.502, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.504, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5222,7 +5231,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 8 }, { ptr, i64 } { ptr @str.505, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.506, i64 8 }, { ptr, i64 } { ptr @str.507, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5241,24 +5250,24 @@ while.body.229: ; preds = %while.hdr.228 while.exit.230: ; preds = %while.hdr.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 1 }) ret { ptr, i64 } %callN if.then.231: ; preds = %while.body.229 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.232 if.merge.232: ; preds = %if.then.231, %while.body.229 %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.511, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.513, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5310,7 +5319,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 7 }, { ptr, i64 } { ptr @str.514, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 7 }, { ptr, i64 } { ptr @str.516, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5329,24 +5338,24 @@ while.body.234: ; preds = %while.hdr.233 while.exit.235: ; preds = %while.hdr.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.517, i64 1 }) ret { ptr, i64 } %callN if.then.236: ; preds = %while.body.234 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.237 if.merge.237: ; preds = %if.then.236, %while.body.234 %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.520, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.522, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5398,7 +5407,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.522, i64 9 }, { ptr, i64 } { ptr @str.523, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 9 }, { ptr, i64 } { ptr @str.525, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5417,24 +5426,24 @@ while.body.239: ; preds = %while.hdr.238 while.exit.240: ; preds = %while.hdr.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 1 }) ret { ptr, i64 } %callN if.then.241: ; preds = %while.body.239 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.242 if.merge.242: ; preds = %if.then.241, %while.body.239 %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.528, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.530, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5477,7 +5486,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 4 }, { ptr, i64 } { ptr @str.531, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.532, i64 4 }, { ptr, i64 } { ptr @str.533, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5496,24 +5505,24 @@ while.body.244: ; preds = %while.hdr.243 while.exit.245: ; preds = %while.hdr.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 1 }) ret { ptr, i64 } %callN if.then.246: ; preds = %while.body.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.533, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.247 if.merge.247: ; preds = %if.then.246, %while.body.244 %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.536, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.538, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5559,7 +5568,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 6 }, { ptr, i64 } { ptr @str.539, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5578,24 +5587,24 @@ while.body.249: ; preds = %while.hdr.248 while.exit.250: ; preds = %while.hdr.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 1 }) ret { ptr, i64 } %callN if.then.251: ; preds = %while.body.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.252 if.merge.252: ; preds = %if.then.251, %while.body.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.549, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.551, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5677,7 +5686,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, i64 6 }, { ptr, i64 } { ptr @str.552, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 6 }, { ptr, i64 } { ptr @str.554, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5696,24 +5705,24 @@ while.body.254: ; preds = %while.hdr.253 while.exit.255: ; preds = %while.hdr.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 1 }) ret { ptr, i64 } %callN if.then.256: ; preds = %while.body.254 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.257 if.merge.257: ; preds = %if.then.256, %while.body.254 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5772,9 +5781,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, 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 @@ -5793,8 +5802,8 @@ entry: if.then.265: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -5813,9 +5822,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, 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 @@ -5834,8 +5843,8 @@ entry: if.then.267: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.574, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -5865,9 +5874,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.585, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.576, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.578, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5884,8 +5893,8 @@ entry: if.then.269: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.584, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 @@ -5963,9 +5972,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.594, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, 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 @@ -5984,8 +5993,8 @@ entry: if.then.271: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.595, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.598, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 @@ -6004,9 +6013,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.605, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.597, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, 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 @@ -6025,8 +6034,8 @@ entry: if.then.273: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.274 @@ -6043,7 +6052,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.608, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.283 @@ -6060,12 +6069,12 @@ while.body.284: ; preds = %while.hdr.283 while.exit.285: ; preds = %while.hdr.283 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 1 }) ret { ptr, i64 } %call if.then.286: ; preds = %while.body.284 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.287 @@ -6094,7 +6103,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.611, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.288 @@ -6111,12 +6120,12 @@ while.body.289: ; preds = %while.hdr.288 while.exit.290: ; preds = %while.hdr.288 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) ret { ptr, i64 } %call if.then.291: ; preds = %while.body.289 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.292 @@ -6146,7 +6155,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.614, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.293 @@ -6163,12 +6172,12 @@ while.body.294: ; preds = %while.hdr.293 while.exit.295: ; preds = %while.hdr.293 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 1 }) ret { ptr, i64 } %call if.then.296: ; preds = %while.body.294 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.297 @@ -6196,7 +6205,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.617, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.298 @@ -6213,12 +6222,12 @@ while.body.299: ; preds = %while.hdr.298 while.exit.300: ; preds = %while.hdr.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) ret { ptr, i64 } %call if.then.301: ; preds = %while.body.299 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.302 @@ -6247,7 +6256,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.620, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.303 @@ -6264,12 +6273,12 @@ while.body.304: ; preds = %while.hdr.303 while.exit.305: ; preds = %while.hdr.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 1 }) ret { ptr, i64 } %call if.then.306: ; preds = %while.body.304 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.307 @@ -6298,7 +6307,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.623, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.308 @@ -6315,12 +6324,12 @@ while.body.309: ; preds = %while.hdr.308 while.exit.310: ; preds = %while.hdr.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) ret { ptr, i64 } %call if.then.311: ; preds = %while.body.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.312 @@ -6350,7 +6359,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.626, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -6369,12 +6378,12 @@ while.body.321: ; preds = %while.hdr.320 while.exit.322: ; preds = %while.hdr.320 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) ret { ptr, i64 } %call if.then.323: ; preds = %while.body.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -6403,7 +6412,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.629, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.325 @@ -6422,12 +6431,12 @@ while.body.326: ; preds = %while.hdr.325 while.exit.327: ; preds = %while.hdr.325 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 1 }) ret { ptr, i64 } %call if.then.328: ; preds = %while.body.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.329 @@ -6456,7 +6465,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.632, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.330 @@ -6475,12 +6484,12 @@ while.body.331: ; preds = %while.hdr.330 while.exit.332: ; preds = %while.hdr.330 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 1 }) ret { ptr, i64 } %call if.then.333: ; preds = %while.body.331 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.334 @@ -6510,7 +6519,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.633, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.635, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.335 @@ -6529,12 +6538,12 @@ while.body.336: ; preds = %while.hdr.335 while.exit.337: ; preds = %while.hdr.335 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.636, i64 1 }) ret { ptr, i64 } %call if.then.338: ; preds = %while.body.336 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.339 @@ -6564,7 +6573,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.636, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.638, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.340 @@ -6583,12 +6592,12 @@ while.body.341: ; preds = %while.hdr.340 while.exit.342: ; preds = %while.hdr.340 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) ret { ptr, i64 } %call if.then.343: ; preds = %while.body.341 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.638, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.640, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.344 @@ -6630,12 +6639,12 @@ if.then.378: ; preds = %entry if.else.379: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 5 }, { ptr, i64 } %callN) br label %if.merge.380 if.merge.380: ; preds = %if.else.379, %if.then.378 - %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.378 ], [ %callN, %if.else.379 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.378 ], [ %callN, %if.else.379 ] ret { ptr, i64 } %bp } @@ -6658,12 +6667,12 @@ if.then.394: ; preds = %entry if.else.395: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 11 }, { ptr, i64 } %callN) br label %if.merge.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6686,12 +6695,12 @@ if.then.397: ; preds = %entry if.else.398: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 4 }, { ptr, i64 } %callN) br label %if.merge.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6714,12 +6723,12 @@ if.then.400: ; preds = %entry if.else.401: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 11 }, { ptr, i64 } %callN) br label %if.merge.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6742,12 +6751,12 @@ if.then.403: ; preds = %entry if.else.404: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 6 }, { ptr, i64 } %callN) br label %if.merge.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6769,12 +6778,12 @@ if.then.406: ; preds = %entry if.else.407: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 5 }, { ptr, i64 } %callN) br label %if.merge.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6797,12 +6806,12 @@ if.then.409: ; preds = %entry if.else.410: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 9 }, { ptr, i64 } %callN) br label %if.merge.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6825,12 +6834,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 18 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6853,12 +6862,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 5 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6881,12 +6890,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6909,12 +6918,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 4 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -6937,12 +6946,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 9 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -6965,12 +6974,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 4 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -6992,12 +7001,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 8 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7020,12 +7029,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 6 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7047,12 +7056,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 9 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7075,12 +7084,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 7 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7103,12 +7112,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 5 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7131,12 +7140,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 7 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7159,12 +7168,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 4 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7187,12 +7196,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 7 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7215,12 +7224,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 5 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7243,12 +7252,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 7 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7271,12 +7280,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 12 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7299,12 +7308,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 6 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7327,12 +7336,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 10 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 10 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7355,12 +7364,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7383,12 +7392,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 4 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7411,12 +7420,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 7 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7439,12 +7448,12 @@ if.then.478: ; preds = %entry if.else.479: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { ptr, i64 } %callN) br label %if.merge.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7467,12 +7476,12 @@ if.then.481: ; preds = %entry if.else.482: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 5 }, { ptr, i64 } %callN) br label %if.merge.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7488,7 +7497,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.732, i64 4 } + ret { ptr, i64 } { ptr @str.734, i64 4 } if.merge.491: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7512,7 +7521,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.733, i64 4 } + ret { ptr, i64 } { ptr @str.735, i64 4 } if.merge.493: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7536,7 +7545,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.734, i64 4 } + ret { ptr, i64 } { ptr @str.736, i64 4 } if.merge.495: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7560,7 +7569,7 @@ entry: br i1 %lnot, label %if.then.496, label %if.merge.497 if.then.496: ; preds = %entry - ret { ptr, i64 } { ptr @str.735, i64 4 } + ret { ptr, i64 } { ptr @str.737, i64 4 } if.merge.497: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/1009-errors-catch.ir b/examples/expected/1009-errors-catch.ir index a5d97c8..151be73 100644 --- a/examples/expected/1009-errors-catch.ir +++ b/examples/expected/1009-errors-catch.ir @@ -1,621 +1,621 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.126 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.127 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.129 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.130 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.127 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.128 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.129 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [162 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.131 = private constant [9 x i8] c"Overflow\00" -@tag.str.132 = private constant [3 x i8] c"Io\00" -@tag.str.133 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.134 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.135 = private constant [10 x i8] c"BadEscape\00" -@tag.str.136 = private constant [10 x i8] c"BadNumber\00" -@tag.str.137 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.138 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.139 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.140 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.141 = private constant [13 x i8] c"MissingValue\00" -@tag.str.142 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.143 = private constant [13 x i8] c"TooManyFlags\00" -@tag.str.144 = private constant [4 x i8] c"Bad\00" -@tag.str.145 = private constant [6 x i8] c"Empty\00" -@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.131, i64 8 }, { ptr, i64 } { ptr @tag.str.132, i64 2 }, { ptr, i64 } { ptr @tag.str.133, i64 15 }, { ptr, i64 } { ptr @tag.str.134, i64 13 }, { ptr, i64 } { ptr @tag.str.135, i64 9 }, { ptr, i64 } { ptr @tag.str.136, i64 9 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 14 }, { ptr, i64 } { ptr @tag.str.139, i64 14 }, { ptr, i64 } { ptr @tag.str.140, i64 11 }, { ptr, i64 } { ptr @tag.str.141, i64 12 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 3 }, { ptr, i64 } { ptr @tag.str.145, i64 5 }] +@tag.str.133 = private constant [9 x i8] c"Overflow\00" +@tag.str.134 = private constant [3 x i8] c"Io\00" +@tag.str.135 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.136 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.137 = private constant [10 x i8] c"BadEscape\00" +@tag.str.138 = private constant [10 x i8] c"BadNumber\00" +@tag.str.139 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.140 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.141 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.142 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.143 = private constant [13 x i8] c"MissingValue\00" +@tag.str.144 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.145 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.146 = private constant [4 x i8] c"Bad\00" +@tag.str.147 = private constant [6 x i8] c"Empty\00" +@tag_names = private constant [16 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.133, i64 8 }, { ptr, i64 } { ptr @tag.str.134, i64 2 }, { ptr, i64 } { ptr @tag.str.135, i64 15 }, { ptr, i64 } { ptr @tag.str.136, i64 13 }, { ptr, i64 } { ptr @tag.str.137, i64 9 }, { ptr, i64 } { ptr @tag.str.138, i64 9 }, { ptr, i64 } { ptr @tag.str.139, i64 15 }, { ptr, i64 } { ptr @tag.str.140, i64 14 }, { ptr, i64 } { ptr @tag.str.141, i64 14 }, { ptr, i64 } { ptr @tag.str.142, i64 11 }, { ptr, i64 } { ptr @tag.str.143, i64 12 }, { ptr, i64 } { ptr @tag.str.144, i64 15 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 3 }, { ptr, i64 } { ptr @tag.str.147, i64 5 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.146 = private constant [5 x i8] c"bool\00" -@tn.str.147 = private constant [3 x i8] c"s8\00" -@tn.str.148 = private constant [4 x i8] c"s16\00" -@tn.str.149 = private constant [4 x i8] c"s32\00" -@tn.str.150 = private constant [4 x i8] c"s64\00" -@tn.str.151 = private constant [3 x i8] c"u8\00" -@tn.str.152 = private constant [4 x i8] c"u16\00" -@tn.str.153 = private constant [4 x i8] c"u32\00" -@tn.str.154 = private constant [4 x i8] c"u64\00" -@tn.str.155 = private constant [4 x i8] c"f32\00" -@tn.str.156 = private constant [4 x i8] c"f64\00" -@tn.str.157 = private constant [7 x i8] c"string\00" -@tn.str.158 = private constant [4 x i8] c"Any\00" -@tn.str.159 = private constant [9 x i8] c"noreturn\00" -@tn.str.160 = private constant [6 x i8] c"isize\00" -@tn.str.161 = private constant [6 x i8] c"usize\00" -@tn.str.162 = private constant [5 x i8] c"void\00" -@tn.str.163 = private constant [6 x i8] c"*void\00" -@tn.str.164 = private constant [16 x i8] c"Source_Location\00" -@tn.str.165 = private constant [11 x i8] c"CAllocator\00" -@tn.str.166 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.167 = private constant [4 x i8] c"GPA\00" -@tn.str.168 = private constant [5 x i8] c"*GPA\00" -@tn.str.169 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.170 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.171 = private constant [10 x i8] c"Allocator\00" -@tn.str.172 = private constant [6 x i8] c"Arena\00" -@tn.str.173 = private constant [7 x i8] c"*Arena\00" -@tn.str.174 = private constant [6 x i8] c"[*]u8\00" -@tn.str.175 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.176 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.177 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.178 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.179 = private constant [8 x i8] c"Context\00" -@tn.str.180 = private constant [7 x i8] c"[4]s64\00" -@tn.str.181 = private constant [9 x i8] c"[]string\00" -@tn.str.182 = private constant [9 x i8] c"OpenMode\00" -@tn.str.183 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.184 = private constant [5 x i8] c"File\00" -@tn.str.185 = private constant [6 x i8] c"*File\00" -@tn.str.186 = private constant [6 x i8] c"?File\00" -@tn.str.187 = private constant [8 x i8] c"?string\00" -@tn.str.188 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.189 = private constant [4 x i8] c"*u8\00" -@tn.str.190 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.191 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.192 = private constant [5 x i8] c"*s32\00" -@tn.str.193 = private constant [9 x i8] c"SockAddr\00" -@tn.str.194 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.195 = private constant [5 x i8] c"*u32\00" -@tn.str.196 = private constant [10 x i8] c"JsonError\00" -@tn.str.197 = private constant [6 x i8] c"Array\00" -@tn.str.198 = private constant [7 x i8] c"Object\00" -@tn.str.199 = private constant [6 x i8] c"Value\00" -@tn.str.200 = private constant [7 x i8] c"Member\00" -@tn.str.201 = private constant [9 x i8] c"[*]Value\00" -@tn.str.202 = private constant [7 x i8] c"*Array\00" -@tn.str.203 = private constant [10 x i8] c"[*]Member\00" -@tn.str.204 = private constant [8 x i8] c"*Object\00" -@tn.str.205 = private constant [5 x i8] c"[]u8\00" -@tn.str.206 = private constant [5 x i8] c"Sink\00" -@tn.str.207 = private constant [6 x i8] c"*Sink\00" -@tn.str.208 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.209 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.210 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.211 = private constant [7 x i8] c"Parser\00" -@tn.str.212 = private constant [8 x i8] c"*Parser\00" -@tn.str.213 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.214 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.215 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.216 = private constant [13 x i8] c"Architecture\00" -@tn.str.217 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.218 = private constant [11 x i8] c"() -> bool\00" -@tn.str.219 = private constant [5 x i8] c"*s64\00" -@tn.str.220 = private constant [9 x i8] c"CliError\00" -@tn.str.221 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.222 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.223 = private constant [8 x i8] c"Command\00" -@tn.str.224 = private constant [10 x i8] c"FlagValue\00" -@tn.str.225 = private constant [5 x i8] c"Diag\00" -@tn.str.226 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.227 = private constant [7 x i8] c"Parsed\00" -@tn.str.228 = private constant [8 x i8] c"*Parsed\00" -@tn.str.229 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.230 = private constant [10 x i8] c"[]Command\00" -@tn.str.231 = private constant [6 x i8] c"*Diag\00" -@tn.str.232 = private constant [7 x i8] c"[8]s64\00" -@tn.str.233 = private constant [7 x i8] c"[64]u8\00" -@tn.str.234 = private constant [7 x i8] c"Sha256\00" -@tn.str.235 = private constant [8 x i8] c"*Sha256\00" -@tn.str.236 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.237 = private constant [8 x i8] c"[64]s64\00" -@tn.str.238 = private constant [2 x i8] c"E\00" -@tn.str.239 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.240 = private constant [7 x i8] c"**void\00" -@tn.str.241 = private constant [3 x i8] c"*E\00" -@tn.str.242 = private constant [8 x i8] c"*string\00" -@tn.str.243 = private constant [6 x i8] c"[]Any\00" -@tn.str.244 = private constant [5 x i8] c"*Any\00" -@tn.str.245 = private constant [7 x i8] c"[1]Any\00" -@tn.str.246 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.247 = private constant [7 x i8] c"*[]Any\00" -@tn.str.248 = private constant [6 x i8] c"*bool\00" -@tn.str.249 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.250 = private constant [5 x i8] c"*f64\00" -@tn.str.251 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.252 = private constant [11 x i8] c"*Allocator\00" -@tn.str.253 = private constant [9 x i8] c"*Context\00" -@tn.str.254 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.255 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.256 = private constant [8 x i8] c"*Member\00" -@tn.str.257 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.258 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.259 = private constant [9 x i8] c"*Command\00" -@tn.str.260 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.261 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.262 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.263 = private constant [7 x i8] c"*Value\00" -@tn.str.264 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.265 = private constant [14 x i8] c"*Architecture\00" -@tn.str.266 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.267 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.268 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.269 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.270 = private constant [10 x i8] c"*[]string\00" -@tn.str.271 = private constant [6 x i8] c"*[]u8\00" -@tn.str.272 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.273 = private constant [11 x i8] c"*[]Command\00" -@tn.str.274 = private constant [6 x i8] c"**GPA\00" -@tn.str.275 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.276 = private constant [8 x i8] c"**Arena\00" -@tn.str.277 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.278 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.279 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.280 = private constant [7 x i8] c"**File\00" -@tn.str.281 = private constant [5 x i8] c"**u8\00" -@tn.str.282 = private constant [6 x i8] c"**s32\00" -@tn.str.283 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.284 = private constant [6 x i8] c"**u32\00" -@tn.str.285 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.286 = private constant [8 x i8] c"**Array\00" -@tn.str.287 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.288 = private constant [9 x i8] c"**Object\00" -@tn.str.289 = private constant [7 x i8] c"**Sink\00" -@tn.str.290 = private constant [9 x i8] c"**Parser\00" -@tn.str.291 = private constant [6 x i8] c"**s64\00" -@tn.str.292 = private constant [9 x i8] c"**Parsed\00" -@tn.str.293 = private constant [7 x i8] c"**Diag\00" -@tn.str.294 = private constant [9 x i8] c"**Sha256\00" -@tn.str.295 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.296 = private constant [8 x i8] c"***void\00" -@tn.str.297 = private constant [4 x i8] c"**E\00" -@tn.str.298 = private constant [9 x i8] c"**string\00" -@tn.str.299 = private constant [6 x i8] c"**Any\00" -@tn.str.300 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.301 = private constant [8 x i8] c"**[]Any\00" -@tn.str.302 = private constant [7 x i8] c"**bool\00" -@tn.str.303 = private constant [7 x i8] c"*?File\00" -@tn.str.304 = private constant [9 x i8] c"*?string\00" -@tn.str.305 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.306 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.146, i64 4 }, { ptr, i64 } { ptr @tn.str.147, i64 2 }, { ptr, i64 } { ptr @tn.str.148, i64 3 }, { ptr, i64 } { ptr @tn.str.149, i64 3 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 2 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 3 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 6 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 8 }, { ptr, i64 } { ptr @tn.str.160, i64 5 }, { ptr, i64 } { ptr @tn.str.161, i64 5 }, { ptr, i64 } { ptr @tn.str.162, i64 4 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 15 }, { ptr, i64 } { ptr @tn.str.165, i64 10 }, { ptr, i64 } { ptr @tn.str.166, i64 11 }, { ptr, i64 } { ptr @tn.str.167, i64 3 }, { ptr, i64 } { ptr @tn.str.168, i64 4 }, { ptr, i64 } { ptr @tn.str.169, i64 10 }, { ptr, i64 } { ptr @tn.str.170, i64 11 }, { ptr, i64 } { ptr @tn.str.171, i64 9 }, { ptr, i64 } { ptr @tn.str.172, i64 5 }, { ptr, i64 } { ptr @tn.str.173, i64 6 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 8 }, { ptr, i64 } { ptr @tn.str.176, i64 9 }, { ptr, i64 } { ptr @tn.str.177, i64 17 }, { ptr, i64 } { ptr @tn.str.178, i64 18 }, { ptr, i64 } { ptr @tn.str.179, i64 7 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 4 }, { ptr, i64 } { ptr @tn.str.185, i64 5 }, { ptr, i64 } { ptr @tn.str.186, i64 5 }, { ptr, i64 } { ptr @tn.str.187, i64 7 }, { ptr, i64 } { ptr @tn.str.188, i64 10 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 13 }, { ptr, i64 } { ptr @tn.str.191, i64 14 }, { ptr, i64 } { ptr @tn.str.192, i64 4 }, { ptr, i64 } { ptr @tn.str.193, i64 8 }, { ptr, i64 } { ptr @tn.str.194, i64 9 }, { ptr, i64 } { ptr @tn.str.195, i64 4 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 6 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 8 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 9 }, { ptr, i64 } { ptr @tn.str.204, i64 7 }, { ptr, i64 } { ptr @tn.str.205, i64 4 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 16 }, { ptr, i64 } { ptr @tn.str.209, i64 14 }, { ptr, i64 } { ptr @tn.str.210, i64 21 }, { ptr, i64 } { ptr @tn.str.211, i64 6 }, { ptr, i64 } { ptr @tn.str.212, i64 7 }, { ptr, i64 } { ptr @tn.str.213, i64 24 }, { ptr, i64 } { ptr @tn.str.214, i64 23 }, { ptr, i64 } { ptr @tn.str.215, i64 15 }, { ptr, i64 } { ptr @tn.str.216, i64 12 }, { ptr, i64 } { ptr @tn.str.217, i64 12 }, { ptr, i64 } { ptr @tn.str.218, i64 10 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 7 }, { ptr, i64 } { ptr @tn.str.224, i64 9 }, { ptr, i64 } { ptr @tn.str.225, i64 4 }, { ptr, i64 } { ptr @tn.str.226, i64 13 }, { ptr, i64 } { ptr @tn.str.227, i64 6 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 18 }, { ptr, i64 } { ptr @tn.str.230, i64 9 }, { ptr, i64 } { ptr @tn.str.231, i64 5 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 7 }, { ptr, i64 } { ptr @tn.str.236, i64 7 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 1 }, { ptr, i64 } { ptr @tn.str.239, i64 12 }, { ptr, i64 } { ptr @tn.str.240, i64 6 }, { ptr, i64 } { ptr @tn.str.241, i64 2 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 5 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 16 }, { ptr, i64 } { ptr @tn.str.252, i64 10 }, { ptr, i64 } { ptr @tn.str.253, i64 8 }, { ptr, i64 } { ptr @tn.str.254, i64 11 }, { ptr, i64 } { ptr @tn.str.255, i64 14 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 13 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 6 }, { ptr, i64 } { ptr @tn.str.264, i64 16 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 9 }, { ptr, i64 } { ptr @tn.str.271, i64 5 }, { ptr, i64 } { ptr @tn.str.272, i64 11 }, { ptr, i64 } { ptr @tn.str.273, i64 10 }, { ptr, i64 } { ptr @tn.str.274, i64 5 }, { ptr, i64 } { ptr @tn.str.275, i64 12 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 10 }, { ptr, i64 } { ptr @tn.str.279, i64 19 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 4 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 10 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 9 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 8 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 5 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 13 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 3 }, { ptr, i64 } { ptr @tn.str.298, i64 8 }, { ptr, i64 } { ptr @tn.str.299, i64 5 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 7 }, { ptr, i64 } { ptr @tn.str.302, i64 6 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 15 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }] -@str.307 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.308 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.148 = private constant [5 x i8] c"bool\00" +@tn.str.149 = private constant [3 x i8] c"s8\00" +@tn.str.150 = private constant [4 x i8] c"s16\00" +@tn.str.151 = private constant [4 x i8] c"s32\00" +@tn.str.152 = private constant [4 x i8] c"s64\00" +@tn.str.153 = private constant [3 x i8] c"u8\00" +@tn.str.154 = private constant [4 x i8] c"u16\00" +@tn.str.155 = private constant [4 x i8] c"u32\00" +@tn.str.156 = private constant [4 x i8] c"u64\00" +@tn.str.157 = private constant [4 x i8] c"f32\00" +@tn.str.158 = private constant [4 x i8] c"f64\00" +@tn.str.159 = private constant [7 x i8] c"string\00" +@tn.str.160 = private constant [4 x i8] c"Any\00" +@tn.str.161 = private constant [9 x i8] c"noreturn\00" +@tn.str.162 = private constant [6 x i8] c"isize\00" +@tn.str.163 = private constant [6 x i8] c"usize\00" +@tn.str.164 = private constant [5 x i8] c"void\00" +@tn.str.165 = private constant [6 x i8] c"*void\00" +@tn.str.166 = private constant [16 x i8] c"Source_Location\00" +@tn.str.167 = private constant [10 x i8] c"Allocator\00" +@tn.str.168 = private constant [11 x i8] c"CAllocator\00" +@tn.str.169 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.170 = private constant [4 x i8] c"GPA\00" +@tn.str.171 = private constant [5 x i8] c"*GPA\00" +@tn.str.172 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.173 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.174 = private constant [6 x i8] c"Arena\00" +@tn.str.175 = private constant [7 x i8] c"*Arena\00" +@tn.str.176 = private constant [6 x i8] c"[*]u8\00" +@tn.str.177 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.178 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.179 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.180 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.181 = private constant [8 x i8] c"Context\00" +@tn.str.182 = private constant [7 x i8] c"[4]s64\00" +@tn.str.183 = private constant [9 x i8] c"[]string\00" +@tn.str.184 = private constant [9 x i8] c"OpenMode\00" +@tn.str.185 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.186 = private constant [5 x i8] c"File\00" +@tn.str.187 = private constant [6 x i8] c"*File\00" +@tn.str.188 = private constant [6 x i8] c"?File\00" +@tn.str.189 = private constant [8 x i8] c"?string\00" +@tn.str.190 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.191 = private constant [4 x i8] c"*u8\00" +@tn.str.192 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.193 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.194 = private constant [5 x i8] c"*s32\00" +@tn.str.195 = private constant [9 x i8] c"SockAddr\00" +@tn.str.196 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.197 = private constant [5 x i8] c"*u32\00" +@tn.str.198 = private constant [10 x i8] c"JsonError\00" +@tn.str.199 = private constant [6 x i8] c"Array\00" +@tn.str.200 = private constant [7 x i8] c"Object\00" +@tn.str.201 = private constant [6 x i8] c"Value\00" +@tn.str.202 = private constant [7 x i8] c"Member\00" +@tn.str.203 = private constant [9 x i8] c"[*]Value\00" +@tn.str.204 = private constant [7 x i8] c"*Array\00" +@tn.str.205 = private constant [10 x i8] c"[*]Member\00" +@tn.str.206 = private constant [8 x i8] c"*Object\00" +@tn.str.207 = private constant [5 x i8] c"[]u8\00" +@tn.str.208 = private constant [5 x i8] c"Sink\00" +@tn.str.209 = private constant [6 x i8] c"*Sink\00" +@tn.str.210 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.211 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.212 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.213 = private constant [7 x i8] c"Parser\00" +@tn.str.214 = private constant [8 x i8] c"*Parser\00" +@tn.str.215 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.216 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.217 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.218 = private constant [13 x i8] c"Architecture\00" +@tn.str.219 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.220 = private constant [11 x i8] c"() -> bool\00" +@tn.str.221 = private constant [5 x i8] c"*s64\00" +@tn.str.222 = private constant [9 x i8] c"CliError\00" +@tn.str.223 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.224 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.225 = private constant [8 x i8] c"Command\00" +@tn.str.226 = private constant [10 x i8] c"FlagValue\00" +@tn.str.227 = private constant [5 x i8] c"Diag\00" +@tn.str.228 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.229 = private constant [7 x i8] c"Parsed\00" +@tn.str.230 = private constant [8 x i8] c"*Parsed\00" +@tn.str.231 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.232 = private constant [10 x i8] c"[]Command\00" +@tn.str.233 = private constant [6 x i8] c"*Diag\00" +@tn.str.234 = private constant [7 x i8] c"[8]s64\00" +@tn.str.235 = private constant [7 x i8] c"[64]u8\00" +@tn.str.236 = private constant [7 x i8] c"Sha256\00" +@tn.str.237 = private constant [8 x i8] c"*Sha256\00" +@tn.str.238 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.239 = private constant [8 x i8] c"[64]s64\00" +@tn.str.240 = private constant [2 x i8] c"E\00" +@tn.str.241 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.242 = private constant [7 x i8] c"**void\00" +@tn.str.243 = private constant [3 x i8] c"*E\00" +@tn.str.244 = private constant [8 x i8] c"*string\00" +@tn.str.245 = private constant [6 x i8] c"[]Any\00" +@tn.str.246 = private constant [5 x i8] c"*Any\00" +@tn.str.247 = private constant [7 x i8] c"[1]Any\00" +@tn.str.248 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.249 = private constant [7 x i8] c"*[]Any\00" +@tn.str.250 = private constant [6 x i8] c"*bool\00" +@tn.str.251 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.252 = private constant [5 x i8] c"*f64\00" +@tn.str.253 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.254 = private constant [11 x i8] c"*Allocator\00" +@tn.str.255 = private constant [9 x i8] c"*Context\00" +@tn.str.256 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.257 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.258 = private constant [8 x i8] c"*Member\00" +@tn.str.259 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.260 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.261 = private constant [9 x i8] c"*Command\00" +@tn.str.262 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.263 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.264 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.265 = private constant [7 x i8] c"*Value\00" +@tn.str.266 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.267 = private constant [14 x i8] c"*Architecture\00" +@tn.str.268 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.269 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.270 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.271 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.272 = private constant [10 x i8] c"*[]string\00" +@tn.str.273 = private constant [6 x i8] c"*[]u8\00" +@tn.str.274 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.275 = private constant [11 x i8] c"*[]Command\00" +@tn.str.276 = private constant [6 x i8] c"**GPA\00" +@tn.str.277 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.278 = private constant [8 x i8] c"**Arena\00" +@tn.str.279 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.280 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.281 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.282 = private constant [7 x i8] c"**File\00" +@tn.str.283 = private constant [5 x i8] c"**u8\00" +@tn.str.284 = private constant [6 x i8] c"**s32\00" +@tn.str.285 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.286 = private constant [6 x i8] c"**u32\00" +@tn.str.287 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.288 = private constant [8 x i8] c"**Array\00" +@tn.str.289 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.290 = private constant [9 x i8] c"**Object\00" +@tn.str.291 = private constant [7 x i8] c"**Sink\00" +@tn.str.292 = private constant [9 x i8] c"**Parser\00" +@tn.str.293 = private constant [6 x i8] c"**s64\00" +@tn.str.294 = private constant [9 x i8] c"**Parsed\00" +@tn.str.295 = private constant [7 x i8] c"**Diag\00" +@tn.str.296 = private constant [9 x i8] c"**Sha256\00" +@tn.str.297 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.298 = private constant [8 x i8] c"***void\00" +@tn.str.299 = private constant [4 x i8] c"**E\00" +@tn.str.300 = private constant [9 x i8] c"**string\00" +@tn.str.301 = private constant [6 x i8] c"**Any\00" +@tn.str.302 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.303 = private constant [8 x i8] c"**[]Any\00" +@tn.str.304 = private constant [7 x i8] c"**bool\00" +@tn.str.305 = private constant [7 x i8] c"*?File\00" +@tn.str.306 = private constant [9 x i8] c"*?string\00" +@tn.str.307 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.308 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.148, i64 4 }, { ptr, i64 } { ptr @tn.str.149, i64 2 }, { ptr, i64 } { ptr @tn.str.150, i64 3 }, { ptr, i64 } { ptr @tn.str.151, i64 3 }, { ptr, i64 } { ptr @tn.str.152, i64 3 }, { ptr, i64 } { ptr @tn.str.153, i64 2 }, { ptr, i64 } { ptr @tn.str.154, i64 3 }, { ptr, i64 } { ptr @tn.str.155, i64 3 }, { ptr, i64 } { ptr @tn.str.156, i64 3 }, { ptr, i64 } { ptr @tn.str.157, i64 3 }, { ptr, i64 } { ptr @tn.str.158, i64 3 }, { ptr, i64 } { ptr @tn.str.159, i64 6 }, { ptr, i64 } { ptr @tn.str.160, i64 3 }, { ptr, i64 } { ptr @tn.str.161, i64 8 }, { ptr, i64 } { ptr @tn.str.162, i64 5 }, { ptr, i64 } { ptr @tn.str.163, i64 5 }, { ptr, i64 } { ptr @tn.str.164, i64 4 }, { ptr, i64 } { ptr @tn.str.165, i64 5 }, { ptr, i64 } { ptr @tn.str.166, i64 15 }, { ptr, i64 } { ptr @tn.str.167, i64 9 }, { ptr, i64 } { ptr @tn.str.168, i64 10 }, { ptr, i64 } { ptr @tn.str.169, i64 11 }, { ptr, i64 } { ptr @tn.str.170, i64 3 }, { ptr, i64 } { ptr @tn.str.171, i64 4 }, { ptr, i64 } { ptr @tn.str.172, i64 10 }, { ptr, i64 } { ptr @tn.str.173, i64 11 }, { ptr, i64 } { ptr @tn.str.174, i64 5 }, { ptr, i64 } { ptr @tn.str.175, i64 6 }, { ptr, i64 } { ptr @tn.str.176, i64 5 }, { ptr, i64 } { ptr @tn.str.177, i64 8 }, { ptr, i64 } { ptr @tn.str.178, i64 9 }, { ptr, i64 } { ptr @tn.str.179, i64 17 }, { ptr, i64 } { ptr @tn.str.180, i64 18 }, { ptr, i64 } { ptr @tn.str.181, i64 7 }, { ptr, i64 } { ptr @tn.str.182, i64 6 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 8 }, { ptr, i64 } { ptr @tn.str.185, i64 8 }, { ptr, i64 } { ptr @tn.str.186, i64 4 }, { ptr, i64 } { ptr @tn.str.187, i64 5 }, { ptr, i64 } { ptr @tn.str.188, i64 5 }, { ptr, i64 } { ptr @tn.str.189, i64 7 }, { ptr, i64 } { ptr @tn.str.190, i64 10 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 13 }, { ptr, i64 } { ptr @tn.str.193, i64 14 }, { ptr, i64 } { ptr @tn.str.194, i64 4 }, { ptr, i64 } { ptr @tn.str.195, i64 8 }, { ptr, i64 } { ptr @tn.str.196, i64 9 }, { ptr, i64 } { ptr @tn.str.197, i64 4 }, { ptr, i64 } { ptr @tn.str.198, i64 9 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 6 }, { ptr, i64 } { ptr @tn.str.201, i64 5 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 8 }, { ptr, i64 } { ptr @tn.str.204, i64 6 }, { ptr, i64 } { ptr @tn.str.205, i64 9 }, { ptr, i64 } { ptr @tn.str.206, i64 7 }, { ptr, i64 } { ptr @tn.str.207, i64 4 }, { ptr, i64 } { ptr @tn.str.208, i64 4 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 16 }, { ptr, i64 } { ptr @tn.str.211, i64 14 }, { ptr, i64 } { ptr @tn.str.212, i64 21 }, { ptr, i64 } { ptr @tn.str.213, i64 6 }, { ptr, i64 } { ptr @tn.str.214, i64 7 }, { ptr, i64 } { ptr @tn.str.215, i64 24 }, { ptr, i64 } { ptr @tn.str.216, i64 23 }, { ptr, i64 } { ptr @tn.str.217, i64 15 }, { ptr, i64 } { ptr @tn.str.218, i64 12 }, { ptr, i64 } { ptr @tn.str.219, i64 12 }, { ptr, i64 } { ptr @tn.str.220, i64 10 }, { ptr, i64 } { ptr @tn.str.221, i64 4 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 8 }, { ptr, i64 } { ptr @tn.str.224, i64 10 }, { ptr, i64 } { ptr @tn.str.225, i64 7 }, { ptr, i64 } { ptr @tn.str.226, i64 9 }, { ptr, i64 } { ptr @tn.str.227, i64 4 }, { ptr, i64 } { ptr @tn.str.228, i64 13 }, { ptr, i64 } { ptr @tn.str.229, i64 6 }, { ptr, i64 } { ptr @tn.str.230, i64 7 }, { ptr, i64 } { ptr @tn.str.231, i64 18 }, { ptr, i64 } { ptr @tn.str.232, i64 9 }, { ptr, i64 } { ptr @tn.str.233, i64 5 }, { ptr, i64 } { ptr @tn.str.234, i64 6 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 6 }, { ptr, i64 } { ptr @tn.str.237, i64 7 }, { ptr, i64 } { ptr @tn.str.238, i64 7 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 1 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 2 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 5 }, { ptr, i64 } { ptr @tn.str.246, i64 4 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { ptr, i64 } { ptr @tn.str.250, i64 5 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 4 }, { ptr, i64 } { ptr @tn.str.253, i64 16 }, { ptr, i64 } { ptr @tn.str.254, i64 10 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 11 }, { ptr, i64 } { ptr @tn.str.257, i64 14 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 13 }, { ptr, i64 } { ptr @tn.str.260, i64 9 }, { ptr, i64 } { ptr @tn.str.261, i64 8 }, { ptr, i64 } { ptr @tn.str.262, i64 10 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 6 }, { ptr, i64 } { ptr @tn.str.266, i64 16 }, { ptr, i64 } { ptr @tn.str.267, i64 13 }, { ptr, i64 } { ptr @tn.str.268, i64 14 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 8 }, { ptr, i64 } { ptr @tn.str.272, i64 9 }, { ptr, i64 } { ptr @tn.str.273, i64 5 }, { ptr, i64 } { ptr @tn.str.274, i64 11 }, { ptr, i64 } { ptr @tn.str.275, i64 10 }, { ptr, i64 } { ptr @tn.str.276, i64 5 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 7 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 10 }, { ptr, i64 } { ptr @tn.str.281, i64 19 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 4 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 10 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 9 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 8 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 8 }, { ptr, i64 } { ptr @tn.str.295, i64 6 }, { ptr, i64 } { ptr @tn.str.296, i64 8 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 3 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 5 }, { ptr, i64 } { ptr @tn.str.302, i64 8 }, { ptr, i64 } { ptr @tn.str.303, i64 7 }, { ptr, i64 } { ptr @tn.str.304, i64 6 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 15 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }] @str.309 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.310 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.311 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.312 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.313 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.314 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.315 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.316 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.317 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.318 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.319 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.320 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.321 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.322 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.323 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.324 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.325 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.326 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.327 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.313 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.314 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.315 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.316 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.317 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.318 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.319 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.320 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.321 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.322 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.323 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.324 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.325 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.326 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.327 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.328 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.329 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @frame.str = private unnamed_addr constant [21 x i8] c"1009-errors-catch.sx\00" -@frame.str.328 = private unnamed_addr constant [5 x i8] c"must\00" -@frame.str.329 = private unnamed_addr constant [35 x i8] c" if n < 0 { raise error.Bad; }\00" -@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 16, i32 17, { ptr, i64 } { ptr @frame.str.328, i64 4 }, { ptr, i64 } { ptr @frame.str.329, i64 34 } } -@frame.str.330 = private unnamed_addr constant [37 x i8] c" if n == 0 { raise error.Empty; }\00" -@trace.frame.331 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 17, i32 17, { ptr, i64 } { ptr @frame.str.328, i64 4 }, { ptr, i64 } { ptr @frame.str.330, i64 36 } } -@frame.str.332 = private unnamed_addr constant [12 x i8] c"handle_some\00" -@frame.str.333 = private unnamed_addr constant [65 x i8] c" raise e; // re-raise the rest\00" -@trace.frame.334 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 46, i32 9, { ptr, i64 } { ptr @frame.str.332, i64 11 }, { ptr, i64 } { ptr @frame.str.333, i64 64 } } -@str.335 = private unnamed_addr constant [18 x i8] c"catch result: {}\0A\00", align 1 -@str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@frame.str.330 = private unnamed_addr constant [5 x i8] c"must\00" +@frame.str.331 = private unnamed_addr constant [35 x i8] c" if n < 0 { raise error.Bad; }\00" +@trace.frame = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 16, i32 17, { ptr, i64 } { ptr @frame.str.330, i64 4 }, { ptr, i64 } { ptr @frame.str.331, i64 34 } } +@frame.str.332 = private unnamed_addr constant [37 x i8] c" if n == 0 { raise error.Empty; }\00" +@trace.frame.333 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 17, i32 17, { ptr, i64 } { ptr @frame.str.330, i64 4 }, { ptr, i64 } { ptr @frame.str.332, i64 36 } } +@frame.str.334 = private unnamed_addr constant [12 x i8] c"handle_some\00" +@frame.str.335 = private unnamed_addr constant [65 x i8] c" raise e; // re-raise the rest\00" +@trace.frame.336 = private constant { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } { { ptr, i64 } { ptr @frame.str, i64 20 }, i32 46, i32 9, { ptr, i64 } { ptr @frame.str.334, i64 11 }, { ptr, i64 } { ptr @frame.str.335, i64 64 } } @str.337 = private unnamed_addr constant [18 x i8] c"catch result: {}\0A\00", align 1 -@str.338 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.339 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.340 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.341 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.338 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [18 x i8] c"catch result: {}\0A\00", align 1 +@str.340 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.341 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.342 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.343 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.342 = private constant [5 x i8] c"line\00" -@fld.str.343 = private constant [4 x i8] c"col\00" -@fld.str.344 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.342, i64 4 }, { ptr, i64 } { ptr @fld.str.343, i64 3 }, { ptr, i64 } { ptr @fld.str.344, i64 4 }] -@str.345 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.346 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.347 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.348 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.349 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.350 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.351 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.352 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.353 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.354 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.355 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.356 = private constant [12 x i8] c"alloc_count\00" -@field_names.357 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.356, i64 11 }] -@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.359 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.360 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.361 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.363 = private constant [5 x i8] c"next\00" -@fld.str.364 = private constant [4 x i8] c"cap\00" -@field_names.365 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.363, i64 4 }, { ptr, i64 } { ptr @fld.str.364, i64 3 }] -@str.366 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.367 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.368 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.369 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.371 = private constant [4 x i8] c"ctx\00" -@fld.str.372 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.373 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.374 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.371, i64 3 }, { ptr, i64 } { ptr @fld.str.372, i64 11 }, { ptr, i64 } { ptr @fld.str.373, i64 13 }] -@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.376 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.377 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.378 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.379 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.380 = private constant [6 x i8] c"first\00" -@fld.str.381 = private constant [10 x i8] c"end_index\00" -@fld.str.382 = private constant [7 x i8] c"parent\00" -@field_names.383 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 5 }, { ptr, i64 } { ptr @fld.str.381, i64 9 }, { ptr, i64 } { ptr @fld.str.382, i64 6 }] -@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.385 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.386 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.387 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.388 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.389 = private constant [4 x i8] c"buf\00" -@fld.str.390 = private constant [4 x i8] c"len\00" -@fld.str.391 = private constant [4 x i8] c"pos\00" -@field_names.392 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 3 }, { ptr, i64 } { ptr @fld.str.391, i64 3 }] -@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.394 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.395 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.396 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.397 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.398 = private constant [7 x i8] c"parent\00" -@fld.str.399 = private constant [12 x i8] c"alloc_count\00" -@fld.str.400 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.401 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.402 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 6 }, { ptr, i64 } { ptr @fld.str.399, i64 11 }, { ptr, i64 } { ptr @fld.str.400, i64 13 }, { ptr, i64 } { ptr @fld.str.401, i64 17 }] -@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.404 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.408 = private constant [10 x i8] c"allocator\00" -@fld.str.409 = private constant [5 x i8] c"data\00" -@field_names.410 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 9 }, { ptr, i64 } { ptr @fld.str.409, i64 4 }] -@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.412 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.416 = private constant [3 x i8] c"fd\00" -@field_names.417 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 2 }] -@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.419 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.423 = private constant [5 x i8] c"file\00" -@fld.str.424 = private constant [5 x i8] c"line\00" -@fld.str.425 = private constant [4 x i8] c"col\00" -@fld.str.426 = private constant [5 x i8] c"func\00" -@fld.str.427 = private constant [10 x i8] c"line_text\00" -@field_names.428 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 4 }, { ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 3 }, { ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 9 }] -@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.430 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.434 = private constant [10 x i8] c"exit_code\00" -@fld.str.435 = private constant [7 x i8] c"stdout\00" -@field_names.436 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 9 }, { ptr, i64 } { ptr @fld.str.435, i64 6 }] -@str.437 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.438 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.439 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.440 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.441 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.442 = private constant [8 x i8] c"sin_len\00" -@fld.str.443 = private constant [11 x i8] c"sin_family\00" -@fld.str.444 = private constant [9 x i8] c"sin_port\00" -@fld.str.445 = private constant [9 x i8] c"sin_addr\00" -@fld.str.446 = private constant [9 x i8] c"sin_zero\00" -@field_names.447 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 7 }, { ptr, i64 } { ptr @fld.str.443, i64 10 }, { ptr, i64 } { ptr @fld.str.444, i64 8 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }] -@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.449 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.450 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.451 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.452 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.453 = private constant [6 x i8] c"items\00" -@fld.str.454 = private constant [4 x i8] c"len\00" -@fld.str.455 = private constant [4 x i8] c"cap\00" -@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 5 }, { ptr, i64 } { ptr @fld.str.454, i64 3 }, { ptr, i64 } { ptr @fld.str.455, i64 3 }] -@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.458 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.462 = private constant [6 x i8] c"items\00" -@fld.str.463 = private constant [4 x i8] c"len\00" -@fld.str.464 = private constant [4 x i8] c"cap\00" -@field_names.465 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 5 }, { ptr, i64 } { ptr @fld.str.463, i64 3 }, { ptr, i64 } { ptr @fld.str.464, i64 3 }] -@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.467 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.468 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.469 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.470 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.471 = private constant [4 x i8] c"key\00" -@fld.str.472 = private constant [4 x i8] c"val\00" -@field_names.473 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }] -@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.475 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.476 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.477 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.478 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.479 = private constant [4 x i8] c"dst\00" -@fld.str.480 = private constant [4 x i8] c"pos\00" -@fld.str.481 = private constant [5 x i8] c"file\00" -@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 4 }] -@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.484 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.488 = private constant [4 x i8] c"src\00" -@fld.str.489 = private constant [4 x i8] c"pos\00" -@fld.str.490 = private constant [6 x i8] c"alloc\00" -@field_names.491 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 5 }] -@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.493 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.497 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.498 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.499 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.500 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.502 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.503 = private constant [5 x i8] c"name\00" -@fld.str.504 = private constant [12 x i8] c"takes_value\00" -@fld.str.505 = private constant [9 x i8] c"required\00" -@field_names.506 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.503, i64 4 }, { ptr, i64 } { ptr @fld.str.504, i64 11 }, { ptr, i64 } { ptr @fld.str.505, i64 8 }] -@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.508 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.509 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.511 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.512 = private constant [6 x i8] c"group\00" -@fld.str.513 = private constant [8 x i8] c"command\00" -@fld.str.514 = private constant [6 x i8] c"flags\00" -@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 5 }, { ptr, i64 } { ptr @fld.str.513, i64 7 }, { ptr, i64 } { ptr @fld.str.514, i64 5 }] -@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.517 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.521 = private constant [4 x i8] c"set\00" -@fld.str.522 = private constant [6 x i8] c"value\00" -@field_names.523 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 5 }] -@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.525 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.526 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.527 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.528 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.529 = private constant [6 x i8] c"index\00" -@fld.str.530 = private constant [6 x i8] c"token\00" -@field_names.531 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.529, i64 5 }, { ptr, i64 } { ptr @fld.str.530, i64 5 }] -@str.532 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.533 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.534 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.535 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.536 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.537 = private constant [6 x i8] c"group\00" -@fld.str.538 = private constant [8 x i8] c"command\00" -@fld.str.539 = private constant [10 x i8] c"cmd_index\00" -@fld.str.540 = private constant [5 x i8] c"json\00" -@fld.str.541 = private constant [5 x i8] c"rest\00" -@fld.str.542 = private constant [5 x i8] c"spec\00" -@fld.str.543 = private constant [7 x i8] c"values\00" -@field_names.544 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.537, i64 5 }, { ptr, i64 } { ptr @fld.str.538, i64 7 }, { ptr, i64 } { ptr @fld.str.539, i64 9 }, { ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 6 }] -@str.545 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.546 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.548 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.549 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.550 = private constant [2 x i8] c"h\00" -@fld.str.551 = private constant [4 x i8] c"buf\00" -@fld.str.552 = private constant [8 x i8] c"buf_len\00" -@fld.str.553 = private constant [10 x i8] c"total_len\00" -@field_names.554 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.550, i64 1 }, { ptr, i64 } { ptr @fld.str.551, i64 3 }, { ptr, i64 } { ptr @fld.str.552, i64 7 }, { ptr, i64 } { ptr @fld.str.553, i64 9 }] -@str.555 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.556 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.557 = private constant [5 x i8] c"read\00" -@fld.str.558 = private constant [6 x i8] c"write\00" -@fld.str.559 = private constant [7 x i8] c"append\00" -@fld.str.560 = private constant [11 x i8] c"read_write\00" -@field_names.561 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 5 }, { ptr, i64 } { ptr @fld.str.559, i64 6 }, { ptr, i64 } { ptr @fld.str.560, i64 10 }] -@str.562 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.563 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.564 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.565 = private constant [4 x i8] c"set\00" -@fld.str.566 = private constant [8 x i8] c"current\00" -@fld.str.567 = private constant [4 x i8] c"end\00" -@field_names.568 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 7 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }] -@str.569 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.570 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.571 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.572 = private constant [6 x i8] c"null_\00" -@fld.str.573 = private constant [6 x i8] c"bool_\00" -@fld.str.574 = private constant [5 x i8] c"int_\00" -@fld.str.575 = private constant [4 x i8] c"str\00" -@fld.str.576 = private constant [6 x i8] c"array\00" -@fld.str.577 = private constant [7 x i8] c"object\00" -@field_names.578 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 4 }, { ptr, i64 } { ptr @fld.str.575, i64 3 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }, { ptr, i64 } { ptr @fld.str.577, i64 6 }] -@str.579 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.580 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.581 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.582 = private constant [6 x i8] c"macos\00" -@fld.str.583 = private constant [6 x i8] c"linux\00" -@fld.str.584 = private constant [8 x i8] c"windows\00" -@fld.str.585 = private constant [5 x i8] c"wasm\00" -@fld.str.586 = private constant [4 x i8] c"ios\00" -@fld.str.587 = private constant [8 x i8] c"android\00" -@fld.str.588 = private constant [8 x i8] c"unknown\00" -@field_names.589 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.582, i64 5 }, { ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 4 }, { ptr, i64 } { ptr @fld.str.586, i64 3 }, { ptr, i64 } { ptr @fld.str.587, i64 7 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }] -@str.590 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.591 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.592 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.593 = private constant [8 x i8] c"aarch64\00" -@fld.str.594 = private constant [7 x i8] c"x86_64\00" -@fld.str.595 = private constant [7 x i8] c"wasm32\00" -@fld.str.596 = private constant [7 x i8] c"wasm64\00" -@fld.str.597 = private constant [8 x i8] c"unknown\00" -@field_names.598 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 6 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 7 }] -@str.599 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.601 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.602 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.604 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.606 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.607 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.608 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.611 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.612 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.614 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.615 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.617 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.618 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.619 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.621 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.623 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.624 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.625 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.626 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.627 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.629 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.630 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.631 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.632 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.633 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.634 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.635 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.636 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.637 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.638 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.639 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.640 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.641 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.642 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.643 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.644 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.645 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.646 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.647 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.648 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.649 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.650 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.651 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.652 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.653 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.654 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.655 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.656 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.657 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.658 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.659 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.660 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.661 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.662 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.663 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.664 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.665 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.666 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.667 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.668 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.669 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.670 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.671 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.672 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.673 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.674 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.675 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.676 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.677 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.678 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.679 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.680 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.681 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.682 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.683 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.684 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.685 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.686 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.687 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.688 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.689 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.690 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.691 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.692 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.693 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.722 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.725 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.344 = private constant [5 x i8] c"line\00" +@fld.str.345 = private constant [4 x i8] c"col\00" +@fld.str.346 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.344, i64 4 }, { ptr, i64 } { ptr @fld.str.345, i64 3 }, { ptr, i64 } { ptr @fld.str.346, i64 4 }] +@str.347 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.348 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.349 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.350 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.351 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.352 = private constant [4 x i8] c"ctx\00" +@fld.str.353 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.354 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.355 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.352, i64 3 }, { ptr, i64 } { ptr @fld.str.353, i64 11 }, { ptr, i64 } { ptr @fld.str.354, i64 13 }] +@str.356 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.357 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.358 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.359 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.360 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.361 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.362 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.363 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.364 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.365 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.366 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.367 = private constant [12 x i8] c"alloc_count\00" +@field_names.368 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.367, i64 11 }] +@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.370 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.371 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.372 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.374 = private constant [5 x i8] c"next\00" +@fld.str.375 = private constant [4 x i8] c"cap\00" +@field_names.376 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 4 }, { ptr, i64 } { ptr @fld.str.375, i64 3 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.379 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.380 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.381 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.382 = private constant [6 x i8] c"first\00" +@fld.str.383 = private constant [10 x i8] c"end_index\00" +@fld.str.384 = private constant [7 x i8] c"parent\00" +@field_names.385 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 5 }, { ptr, i64 } { ptr @fld.str.383, i64 9 }, { ptr, i64 } { ptr @fld.str.384, i64 6 }] +@str.386 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.387 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.388 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.389 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.390 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.391 = private constant [4 x i8] c"buf\00" +@fld.str.392 = private constant [4 x i8] c"len\00" +@fld.str.393 = private constant [4 x i8] c"pos\00" +@field_names.394 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.391, i64 3 }, { ptr, i64 } { ptr @fld.str.392, i64 3 }, { ptr, i64 } { ptr @fld.str.393, i64 3 }] +@str.395 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.396 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.397 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.398 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.399 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.400 = private constant [7 x i8] c"parent\00" +@fld.str.401 = private constant [12 x i8] c"alloc_count\00" +@fld.str.402 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.403 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.404 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.400, i64 6 }, { ptr, i64 } { ptr @fld.str.401, i64 11 }, { ptr, i64 } { ptr @fld.str.402, i64 13 }, { ptr, i64 } { ptr @fld.str.403, i64 17 }] +@str.405 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.406 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.407 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.408 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.409 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.410 = private constant [10 x i8] c"allocator\00" +@fld.str.411 = private constant [5 x i8] c"data\00" +@field_names.412 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.410, i64 9 }, { ptr, i64 } { ptr @fld.str.411, i64 4 }] +@str.413 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.414 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.415 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.416 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.417 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.418 = private constant [3 x i8] c"fd\00" +@field_names.419 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.418, i64 2 }] +@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.421 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.422 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.423 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.424 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.425 = private constant [5 x i8] c"file\00" +@fld.str.426 = private constant [5 x i8] c"line\00" +@fld.str.427 = private constant [4 x i8] c"col\00" +@fld.str.428 = private constant [5 x i8] c"func\00" +@fld.str.429 = private constant [10 x i8] c"line_text\00" +@field_names.430 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 4 }, { ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 3 }, { ptr, i64 } { ptr @fld.str.428, i64 4 }, { ptr, i64 } { ptr @fld.str.429, i64 9 }] +@str.431 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.432 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.433 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.434 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.435 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.436 = private constant [10 x i8] c"exit_code\00" +@fld.str.437 = private constant [7 x i8] c"stdout\00" +@field_names.438 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.436, i64 9 }, { ptr, i64 } { ptr @fld.str.437, i64 6 }] +@str.439 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.440 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.441 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.442 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.443 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.444 = private constant [8 x i8] c"sin_len\00" +@fld.str.445 = private constant [11 x i8] c"sin_family\00" +@fld.str.446 = private constant [9 x i8] c"sin_port\00" +@fld.str.447 = private constant [9 x i8] c"sin_addr\00" +@fld.str.448 = private constant [9 x i8] c"sin_zero\00" +@field_names.449 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.444, i64 7 }, { ptr, i64 } { ptr @fld.str.445, i64 10 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }, { ptr, i64 } { ptr @fld.str.447, i64 8 }, { ptr, i64 } { ptr @fld.str.448, i64 8 }] +@str.450 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.451 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.452 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.453 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.454 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.455 = private constant [6 x i8] c"items\00" +@fld.str.456 = private constant [4 x i8] c"len\00" +@fld.str.457 = private constant [4 x i8] c"cap\00" +@field_names.458 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.455, i64 5 }, { ptr, i64 } { ptr @fld.str.456, i64 3 }, { ptr, i64 } { ptr @fld.str.457, i64 3 }] +@str.459 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.460 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.461 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.462 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.463 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.464 = private constant [6 x i8] c"items\00" +@fld.str.465 = private constant [4 x i8] c"len\00" +@fld.str.466 = private constant [4 x i8] c"cap\00" +@field_names.467 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.464, i64 5 }, { ptr, i64 } { ptr @fld.str.465, i64 3 }, { ptr, i64 } { ptr @fld.str.466, i64 3 }] +@str.468 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.469 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.470 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.471 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.472 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.473 = private constant [4 x i8] c"key\00" +@fld.str.474 = private constant [4 x i8] c"val\00" +@field_names.475 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.473, i64 3 }, { ptr, i64 } { ptr @fld.str.474, i64 3 }] +@str.476 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.477 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.478 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.479 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.480 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.481 = private constant [4 x i8] c"dst\00" +@fld.str.482 = private constant [4 x i8] c"pos\00" +@fld.str.483 = private constant [5 x i8] c"file\00" +@field_names.484 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.481, i64 3 }, { ptr, i64 } { ptr @fld.str.482, i64 3 }, { ptr, i64 } { ptr @fld.str.483, i64 4 }] +@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.486 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.487 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.488 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.489 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.490 = private constant [4 x i8] c"src\00" +@fld.str.491 = private constant [4 x i8] c"pos\00" +@fld.str.492 = private constant [6 x i8] c"alloc\00" +@field_names.493 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.490, i64 3 }, { ptr, i64 } { ptr @fld.str.491, i64 3 }, { ptr, i64 } { ptr @fld.str.492, i64 5 }] +@str.494 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.495 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.496 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.497 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.498 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.499 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.501 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.502 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.504 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.505 = private constant [5 x i8] c"name\00" +@fld.str.506 = private constant [12 x i8] c"takes_value\00" +@fld.str.507 = private constant [9 x i8] c"required\00" +@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 4 }, { ptr, i64 } { ptr @fld.str.506, i64 11 }, { ptr, i64 } { ptr @fld.str.507, i64 8 }] +@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.510 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.514 = private constant [6 x i8] c"group\00" +@fld.str.515 = private constant [8 x i8] c"command\00" +@fld.str.516 = private constant [6 x i8] c"flags\00" +@field_names.517 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 5 }, { ptr, i64 } { ptr @fld.str.515, i64 7 }, { ptr, i64 } { ptr @fld.str.516, i64 5 }] +@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.519 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.523 = private constant [4 x i8] c"set\00" +@fld.str.524 = private constant [6 x i8] c"value\00" +@field_names.525 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 3 }, { ptr, i64 } { ptr @fld.str.524, i64 5 }] +@str.526 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.527 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.528 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.529 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.530 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.531 = private constant [6 x i8] c"index\00" +@fld.str.532 = private constant [6 x i8] c"token\00" +@field_names.533 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.531, i64 5 }, { ptr, i64 } { ptr @fld.str.532, i64 5 }] +@str.534 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.535 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.536 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.537 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.538 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.539 = private constant [6 x i8] c"group\00" +@fld.str.540 = private constant [8 x i8] c"command\00" +@fld.str.541 = private constant [10 x i8] c"cmd_index\00" +@fld.str.542 = private constant [5 x i8] c"json\00" +@fld.str.543 = private constant [5 x i8] c"rest\00" +@fld.str.544 = private constant [5 x i8] c"spec\00" +@fld.str.545 = private constant [7 x i8] c"values\00" +@field_names.546 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.539, i64 5 }, { ptr, i64 } { ptr @fld.str.540, i64 7 }, { ptr, i64 } { ptr @fld.str.541, i64 9 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 4 }, { ptr, i64 } { ptr @fld.str.544, i64 4 }, { ptr, i64 } { ptr @fld.str.545, i64 6 }] +@str.547 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.548 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.550 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.551 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.552 = private constant [2 x i8] c"h\00" +@fld.str.553 = private constant [4 x i8] c"buf\00" +@fld.str.554 = private constant [8 x i8] c"buf_len\00" +@fld.str.555 = private constant [10 x i8] c"total_len\00" +@field_names.556 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.552, i64 1 }, { ptr, i64 } { ptr @fld.str.553, i64 3 }, { ptr, i64 } { ptr @fld.str.554, i64 7 }, { ptr, i64 } { ptr @fld.str.555, i64 9 }] +@str.557 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.558 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.559 = private constant [5 x i8] c"read\00" +@fld.str.560 = private constant [6 x i8] c"write\00" +@fld.str.561 = private constant [7 x i8] c"append\00" +@fld.str.562 = private constant [11 x i8] c"read_write\00" +@field_names.563 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.559, i64 4 }, { ptr, i64 } { ptr @fld.str.560, i64 5 }, { ptr, i64 } { ptr @fld.str.561, i64 6 }, { ptr, i64 } { ptr @fld.str.562, i64 10 }] +@str.564 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.565 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.566 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.567 = private constant [4 x i8] c"set\00" +@fld.str.568 = private constant [8 x i8] c"current\00" +@fld.str.569 = private constant [4 x i8] c"end\00" +@field_names.570 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.567, i64 3 }, { ptr, i64 } { ptr @fld.str.568, i64 7 }, { ptr, i64 } { ptr @fld.str.569, i64 3 }] +@str.571 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.572 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.573 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.574 = private constant [6 x i8] c"null_\00" +@fld.str.575 = private constant [6 x i8] c"bool_\00" +@fld.str.576 = private constant [5 x i8] c"int_\00" +@fld.str.577 = private constant [4 x i8] c"str\00" +@fld.str.578 = private constant [6 x i8] c"array\00" +@fld.str.579 = private constant [7 x i8] c"object\00" +@field_names.580 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 5 }, { ptr, i64 } { ptr @fld.str.575, i64 5 }, { ptr, i64 } { ptr @fld.str.576, i64 4 }, { ptr, i64 } { ptr @fld.str.577, i64 3 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 6 }] +@str.581 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.582 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.583 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.584 = private constant [6 x i8] c"macos\00" +@fld.str.585 = private constant [6 x i8] c"linux\00" +@fld.str.586 = private constant [8 x i8] c"windows\00" +@fld.str.587 = private constant [5 x i8] c"wasm\00" +@fld.str.588 = private constant [4 x i8] c"ios\00" +@fld.str.589 = private constant [8 x i8] c"android\00" +@fld.str.590 = private constant [8 x i8] c"unknown\00" +@field_names.591 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.584, i64 5 }, { ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 7 }, { ptr, i64 } { ptr @fld.str.587, i64 4 }, { ptr, i64 } { ptr @fld.str.588, i64 3 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }] +@str.592 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.593 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.594 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.595 = private constant [8 x i8] c"aarch64\00" +@fld.str.596 = private constant [7 x i8] c"x86_64\00" +@fld.str.597 = private constant [7 x i8] c"wasm32\00" +@fld.str.598 = private constant [7 x i8] c"wasm64\00" +@fld.str.599 = private constant [8 x i8] c"unknown\00" +@field_names.600 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.595, i64 7 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 6 }, { ptr, i64 } { ptr @fld.str.598, i64 6 }, { ptr, i64 } { ptr @fld.str.599, i64 7 }] +@str.601 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.603 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.604 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.605 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.606 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.608 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.609 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.610 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.613 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.614 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.616 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.619 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.620 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.621 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.625 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.626 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.627 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.628 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.629 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.631 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.632 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.633 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.634 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.635 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.636 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.637 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.638 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.639 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.640 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.641 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.642 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.643 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.644 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.645 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.646 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.648 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.649 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.650 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.651 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.652 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.653 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.654 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.655 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.656 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.657 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.658 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.659 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.660 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.661 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.662 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.663 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.664 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.665 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.666 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.667 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.668 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.670 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.671 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.672 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.673 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.674 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.675 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.676 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.677 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.678 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.679 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.680 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.681 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.682 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.683 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.684 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.686 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.687 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.688 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.689 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.690 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.691 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.692 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.693 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.694 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.695 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [11 x i8] c"*error_set\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.721 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.724 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.727 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -628,6 +628,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -847,7 +850,7 @@ entry: br i1 %icmp, label %if.then.86, label %if.merge.87 if.then.86: ; preds = %entry - ret { ptr, i64 } { ptr @str.125, i64 1 } + ret { ptr, i64 } { ptr @str.127, i64 1 } if.merge.87: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -974,7 +977,7 @@ if.else.109: ; preds = %entry br label %if.merge.110 if.merge.110: ; preds = %if.else.109, %if.then.108 - %bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.108 ], [ { ptr @str.127, i64 5 }, %if.else.109 ] + %bp = phi { ptr, i64 } [ { ptr @str.128, i64 4 }, %if.then.108 ], [ { ptr @str.129, i64 5 }, %if.else.109 ] ret { ptr, i64 } %bp } @@ -1308,7 +1311,7 @@ entry: br i1 %icmp, label %if.then.399, label %if.merge.400 if.then.399: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.400: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1458,7 +1461,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.129, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.131, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1484,9 +1487,9 @@ entry: i64 11, label %match.arm.72 i64 19, label %match.arm.73 i64 20, label %match.arm.73 - i64 22, label %match.arm.73 - i64 24, label %match.arm.73 - i64 26, label %match.arm.73 + i64 21, label %match.arm.73 + i64 23, label %match.arm.73 + i64 25, label %match.arm.73 i64 27, label %match.arm.73 i64 30, label %match.arm.73 i64 32, label %match.arm.73 @@ -1528,9 +1531,9 @@ entry: i64 85, label %match.arm.78 i64 98, label %match.arm.78 i64 18, label %match.arm.79 - i64 21, label %match.arm.79 - i64 23, label %match.arm.79 - i64 25, label %match.arm.79 + i64 22, label %match.arm.79 + i64 24, label %match.arm.79 + i64 26, label %match.arm.79 i64 28, label %match.arm.79 i64 29, label %match.arm.79 i64 31, label %match.arm.79 @@ -1570,7 +1573,7 @@ match.merge.67: ; preds = %dispatch.merge.502, ret { ptr, i64 } %loadN match.arm.68: ; preds = %entry - store { ptr, i64 } { ptr @str.130, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 br label %match.merge.67 match.arm.69: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1614,9 +1617,9 @@ match.arm.73: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.125 [ i64 19, label %dispatch.case.126 i64 20, label %dispatch.case.127 - i64 22, label %dispatch.case.128 - i64 24, label %dispatch.case.129 - i64 26, label %dispatch.case.130 + i64 21, label %dispatch.case.128 + i64 23, label %dispatch.case.129 + i64 25, label %dispatch.case.130 i64 27, label %dispatch.case.131 i64 30, label %dispatch.case.132 i64 32, label %dispatch.case.133 @@ -1697,9 +1700,9 @@ match.arm.79: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.364 [ i64 18, label %dispatch.case.365 - i64 21, label %dispatch.case.366 - i64 23, label %dispatch.case.367 - i64 25, label %dispatch.case.368 + i64 22, label %dispatch.case.366 + i64 24, label %dispatch.case.367 + i64 26, label %dispatch.case.368 i64 28, label %dispatch.case.369 i64 29, label %dispatch.case.370 i64 31, label %dispatch.case.371 @@ -1797,7 +1800,7 @@ dispatch.merge.124: ; preds = %dispatch.case.150, br label %match.merge.67 dispatch.default.125: ; preds = %match.arm.73 - store { ptr, i64 } { ptr @str.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.126: ; preds = %match.arm.73 @@ -1811,32 +1814,32 @@ dispatch.case.126: ; preds = %match.arm.73 dispatch.case.127: ; preds = %match.arm.73 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.128: ; preds = %match.arm.73 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.129: ; preds = %match.arm.73 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.130: ; preds = %match.arm.73 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 @@ -2006,7 +2009,7 @@ dispatch.merge.276: ; preds = %dispatch.case.282, br label %match.merge.67 dispatch.default.277: ; preds = %match.arm.74 - store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.276 dispatch.case.278: ; preds = %match.arm.74 @@ -2047,7 +2050,7 @@ dispatch.merge.293: ; preds = %dispatch.case.300, br label %match.merge.67 dispatch.default.294: ; preds = %match.arm.77 - store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.293 dispatch.case.295: ; preds = %match.arm.77 @@ -2104,7 +2107,7 @@ dispatch.merge.331: ; preds = %dispatch.case.337, br label %match.merge.67 dispatch.default.332: ; preds = %match.arm.78 - store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.331 dispatch.case.333: ; preds = %match.arm.78 @@ -2153,7 +2156,7 @@ dispatch.merge.363: ; preds = %dispatch.case.395, br label %match.merge.67 dispatch.default.364: ; preds = %match.arm.79 - store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.363 dispatch.case.365: ; preds = %match.arm.79 @@ -2379,7 +2382,7 @@ dispatch.merge.502: ; preds = %dispatch.case.507, br label %match.merge.67 dispatch.default.503: ; preds = %match.arm.80 - store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.502 dispatch.case.504: ; preds = %match.arm.80 @@ -2421,7 +2424,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.313, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2517,7 +2520,7 @@ if.merge.41: ; preds = %if.merge.55, %if.me if.then.42: ; preds = %if.then.39 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.314, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2525,7 +2528,7 @@ if.then.42: ; preds = %if.then.39 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2535,13 +2538,13 @@ if.then.42: ; preds = %if.then.39 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.43 if.merge.43: ; preds = %if.then.42, %if.then.39 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2549,7 +2552,7 @@ if.merge.43: ; preds = %if.then.42, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2563,7 +2566,7 @@ if.merge.43: ; preds = %if.then.42, %if.the if.then.53: ; preds = %if.else.40 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2571,7 +2574,7 @@ if.then.53: ; preds = %if.else.40 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.320, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2582,7 +2585,7 @@ if.then.53: ; preds = %if.else.40 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.321, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2639,7 +2642,7 @@ if.merge.61: ; preds = %if.merge.64, %if.el if.then.62: ; preds = %if.then.59 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2647,7 +2650,7 @@ if.then.62: ; preds = %if.then.59 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2658,7 +2661,7 @@ if.then.62: ; preds = %if.then.59 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.324, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2678,7 +2681,7 @@ if.merge.64: ; preds = %if.else.63, %if.the if.then.65: ; preds = %while.exit.32 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2686,7 +2689,7 @@ if.then.65: ; preds = %while.exit.32 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.328, 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 @@ -2697,7 +2700,7 @@ if.then.65: ; preds = %while.exit.32 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.327, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.329, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.66 @@ -2707,64 +2710,67 @@ if.merge.66: ; preds = %if.then.65, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2940,163 +2946,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3294,64 +3303,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3381,97 +3390,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3510,7 +3519,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @must(ptr %0, i32 %1) #0 { @@ -3723,7 +3732,7 @@ entry: define internal void @print__ct_sbcb4570e4e0d606e__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.335, i64 17 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.337, i64 17 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3739,7 +3748,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.338, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 14) @@ -3767,7 +3776,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.337, i64 17 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.339, i64 17 }) ret { ptr, i64 } %call } @@ -3778,7 +3787,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.338, i64 15 }, { ptr, i64 } { ptr @str.339, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.340, i64 15 }, { ptr, i64 } { ptr @str.341, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3797,12 +3806,12 @@ while.body.152: ; preds = %while.hdr.151 while.exit.153: ; preds = %while.hdr.151 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 1 }) ret { ptr, i64 } %callN if.then.154: ; preds = %while.body.152 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.155 @@ -3814,7 +3823,7 @@ if.merge.155: ; preds = %if.then.154, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.347, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3867,20 +3876,20 @@ fv.case24: ; preds = %if.merge.155 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.346, i64 10 }, { ptr, i64 } { ptr @str.347, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.348, i64 9 }, { ptr, i64 } { ptr @str.349, 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.156 -while.hdr.156: ; preds = %if.merge.160, %entry +while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -3890,224 +3899,24 @@ while.body.157: ; preds = %while.hdr.156 while.exit.158: ; preds = %while.hdr.156 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, i64 1 }) ret { ptr, i64 } %callN if.then.159: ; preds = %while.body.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.160 if.merge.160: ; preds = %if.then.159, %while.body.157 %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.350, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.355, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.156 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.352, i64 3 }, { ptr, i64 } { ptr @str.353, 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.161 - -while.hdr.161: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.162, label %while.exit.163 - -while.body.162: ; preds = %while.hdr.161 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.164, label %if.merge.165 - -while.exit.163: ; preds = %while.hdr.161 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.354, i64 1 }) - ret { ptr, i64 } %callN - -if.then.164: ; preds = %while.body.162 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.165 - -if.merge.165: ; preds = %if.then.164, %while.body.162 - %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.357, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.161 - -fv.default: ; preds = %if.merge.165 - br label %fv.merge - -fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.359, i64 10 }, { ptr, i64 } { ptr @str.360, 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.166 - -while.hdr.166: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.167, label %while.exit.168 - -while.body.167: ; preds = %while.hdr.166 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.169, label %if.merge.170 - -while.exit.168: ; preds = %while.hdr.166 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 1 }) - ret { ptr, i64 } %callN - -if.then.169: ; preds = %while.body.167 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.170 - -if.merge.170: ; preds = %if.then.169, %while.body.167 - %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.365, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.166 - -fv.default: ; preds = %if.merge.170 - br label %fv.merge - -fv.case: ; preds = %if.merge.170 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.170 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.367, i64 9 }, { ptr, i64 } { ptr @str.368, 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.171 - -while.hdr.171: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.172, label %while.exit.173 - -while.body.172: ; preds = %while.hdr.171 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.174, label %if.merge.175 - -while.exit.173: ; preds = %while.hdr.171 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 1 }) - ret { ptr, i64 } %callN - -if.then.174: ; preds = %while.body.172 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.175 - -if.merge.175: ; preds = %if.then.174, %while.body.172 - %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.374, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, 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 @@ -4126,27 +3935,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.156 + +fv.default: ; preds = %if.merge.160 + br label %fv.merge + +fv.case: ; preds = %if.merge.160 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.160 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.160 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.357, i64 10 }, { ptr, i64 } { ptr @str.358, 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.161 + +while.hdr.161: ; preds = %if.merge.165, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.162, label %while.exit.163 + +while.body.162: ; preds = %while.hdr.161 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.164, label %if.merge.165 + +while.exit.163: ; preds = %while.hdr.161 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 1 }) + ret { ptr, i64 } %callN + +if.then.164: ; preds = %while.body.162 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.165 + +if.merge.165: ; preds = %if.then.164, %while.body.162 + %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.361, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.161 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.363, i64 3 }, { ptr, i64 } { ptr @str.364, 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.166 + +while.hdr.166: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.167, label %while.exit.168 + +while.body.167: ; preds = %while.hdr.166 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.169, label %if.merge.170 + +while.exit.168: ; preds = %while.hdr.166 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 1 }) + ret { ptr, i64 } %callN + +if.then.169: ; preds = %while.body.167 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.170 + +if.merge.170: ; preds = %if.then.169, %while.body.167 + %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.368, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.166 + +fv.default: ; preds = %if.merge.170 + br label %fv.merge + +fv.case: ; preds = %if.merge.170 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 10 }, { ptr, i64 } { ptr @str.371, 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.171 + +while.hdr.171: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.172, label %while.exit.173 + +while.body.172: ; preds = %while.hdr.171 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.174, label %if.merge.175 + +while.exit.173: ; preds = %while.hdr.171 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 1 }) + ret { ptr, i64 } %callN + +if.then.174: ; preds = %while.body.172 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.175 + +if.merge.175: ; preds = %if.then.174, %while.body.172 + %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.376, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.171 fv.default: ; preds = %if.merge.175 br label %fv.merge fv.case: ; preds = %if.merge.175 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.175 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.175 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4156,7 +4165,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 5 }, { ptr, i64 } { ptr @str.377, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 5 }, { ptr, i64 } { ptr @str.379, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4175,24 +4184,24 @@ while.body.177: ; preds = %while.hdr.176 while.exit.178: ; preds = %while.hdr.176 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.378, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.380, i64 1 }) ret { ptr, i64 } %callN if.then.179: ; preds = %while.body.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.381, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.180 if.merge.180: ; preds = %if.then.179, %while.body.177 %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.383, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.385, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.386, 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 @@ -4219,7 +4228,7 @@ fv.default: ; preds = %if.merge.180 fv.case: ; preds = %if.merge.180 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.180 @@ -4231,7 +4240,7 @@ fv.case20: ; preds = %if.merge.180 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4240,7 +4249,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.387, i64 8 }, { ptr, i64 } { ptr @str.388, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4259,24 +4268,24 @@ while.body.182: ; preds = %while.hdr.181 while.exit.183: ; preds = %while.hdr.181 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 1 }) ret { ptr, i64 } %callN if.then.184: ; preds = %while.body.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.185 if.merge.185: ; preds = %if.then.184, %while.body.182 %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.392, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.394, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, 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 @@ -4323,7 +4332,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 17 }, { ptr, i64 } { ptr @str.395, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.396, i64 17 }, { ptr, i64 } { ptr @str.397, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4342,24 +4351,24 @@ while.body.187: ; preds = %while.hdr.186 while.exit.188: ; preds = %while.hdr.186 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, i64 1 }) ret { ptr, i64 } %callN if.then.189: ; preds = %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.190 if.merge.190: ; preds = %if.then.189, %while.body.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.404, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.405, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4388,7 +4397,7 @@ fv.case: ; preds = %if.merge.190 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.190 @@ -4413,7 +4422,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 7 }, { ptr, i64 } { ptr @str.405, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.406, i64 7 }, { ptr, i64 } { ptr @str.407, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4432,24 +4441,24 @@ while.body.192: ; preds = %while.hdr.191 while.exit.193: ; preds = %while.hdr.191 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 1 }) ret { ptr, i64 } %callN if.then.194: ; preds = %while.body.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.409, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.195 if.merge.195: ; preds = %if.then.194, %while.body.192 %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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.412, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, 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 @@ -4476,7 +4485,7 @@ fv.case: ; preds = %if.merge.195 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.195 @@ -4491,7 +4500,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 4 }, { ptr, i64 } { ptr @str.413, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.414, i64 4 }, { ptr, i64 } { ptr @str.415, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4510,24 +4519,24 @@ while.body.197: ; preds = %while.hdr.196 while.exit.198: ; preds = %while.hdr.196 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.416, i64 1 }) ret { ptr, i64 } %callN if.then.199: ; preds = %while.body.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.200 if.merge.200: ; preds = %if.then.199, %while.body.197 %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.417, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.419, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4564,7 +4573,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 10 }, { ptr, i64 } { ptr @str.420, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 10 }, { ptr, i64 } { ptr @str.422, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4583,24 +4592,24 @@ while.body.202: ; preds = %while.hdr.201 while.exit.203: ; preds = %while.hdr.201 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 1 }) ret { ptr, i64 } %callN if.then.204: ; preds = %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.205 if.merge.205: ; preds = %if.then.204, %while.body.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.430, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4666,7 +4675,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 13 }, { ptr, i64 } { ptr @str.431, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.432, i64 13 }, { ptr, i64 } { ptr @str.433, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4685,24 +4694,24 @@ while.body.207: ; preds = %while.hdr.206 while.exit.208: ; preds = %while.hdr.206 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.434, i64 1 }) ret { ptr, i64 } %callN if.then.209: ; preds = %while.body.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.210 if.merge.210: ; preds = %if.then.209, %while.body.207 %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.436, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.438, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4744,7 +4753,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 8 }, { ptr, i64 } { ptr @str.439, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.440, i64 8 }, { ptr, i64 } { ptr @str.441, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4763,24 +4772,24 @@ while.body.212: ; preds = %while.hdr.211 while.exit.213: ; preds = %while.hdr.211 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 1 }) ret { ptr, i64 } %callN if.then.214: ; preds = %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.443, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.215 if.merge.215: ; preds = %if.then.214, %while.body.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.447, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.449, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4841,7 +4850,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 5 }, { ptr, i64 } { ptr @str.450, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.451, i64 5 }, { ptr, i64 } { ptr @str.452, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4860,24 +4869,24 @@ while.body.217: ; preds = %while.hdr.216 while.exit.218: ; preds = %while.hdr.216 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 1 }) ret { ptr, i64 } %callN if.then.219: ; preds = %while.body.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.454, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.220 if.merge.220: ; preds = %if.then.219, %while.body.217 %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.456, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.458, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, 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 @@ -4923,7 +4932,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 6 }, { ptr, i64 } { ptr @str.459, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4942,24 +4951,24 @@ while.body.222: ; preds = %while.hdr.221 while.exit.223: ; preds = %while.hdr.221 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 1 }) ret { ptr, i64 } %callN if.then.224: ; preds = %while.body.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.225 if.merge.225: ; preds = %if.then.224, %while.body.222 %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.465, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.467, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, 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 @@ -5007,7 +5016,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 6 }, { ptr, i64 } { ptr @str.468, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.469, i64 6 }, { ptr, i64 } { ptr @str.470, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5026,24 +5035,24 @@ while.body.227: ; preds = %while.hdr.226 while.exit.228: ; preds = %while.hdr.226 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 1 }) ret { ptr, i64 } %callN if.then.229: ; preds = %while.body.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.230 if.merge.230: ; preds = %if.then.229, %while.body.227 %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.473, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.475, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5087,7 +5096,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 4 }, { ptr, i64 } { ptr @str.476, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.477, i64 4 }, { ptr, i64 } { ptr @str.478, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5106,24 +5115,24 @@ while.body.232: ; preds = %while.hdr.231 while.exit.233: ; preds = %while.hdr.231 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 1 }) ret { ptr, i64 } %callN if.then.234: ; preds = %while.body.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.480, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.235 if.merge.235: ; preds = %if.then.234, %while.body.232 %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.482, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.484, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5173,7 +5182,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 6 }, { ptr, i64 } { ptr @str.485, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 6 }, { ptr, i64 } { ptr @str.487, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5192,24 +5201,24 @@ while.body.237: ; preds = %while.hdr.236 while.exit.238: ; preds = %while.hdr.236 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.488, i64 1 }) ret { ptr, i64 } %callN if.then.239: ; preds = %while.body.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.240 if.merge.240: ; preds = %if.then.239, %while.body.237 %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.491, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.493, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5249,7 +5258,7 @@ fv.case20: ; preds = %if.merge.240 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5258,7 +5267,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 12 }, { ptr, i64 } { ptr @str.494, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 12 }, { ptr, i64 } { ptr @str.496, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5277,24 +5286,24 @@ while.body.242: ; preds = %while.hdr.241 while.exit.243: ; preds = %while.hdr.241 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.497, i64 1 }) ret { ptr, i64 } %callN if.then.244: ; preds = %while.body.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.245 if.merge.245: ; preds = %if.then.244, %while.body.242 %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.497, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.499, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.498, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5314,7 +5323,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.499, i64 8 }, { ptr, i64 } { ptr @str.500, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 8 }, { ptr, i64 } { ptr @str.502, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5333,24 +5342,24 @@ while.body.247: ; preds = %while.hdr.246 while.exit.248: ; preds = %while.hdr.246 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 1 }) ret { ptr, i64 } %callN if.then.249: ; preds = %while.body.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.250 if.merge.250: ; preds = %if.then.249, %while.body.247 %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.506, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.508, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5402,7 +5411,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 7 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 7 }, { ptr, i64 } { ptr @str.511, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5421,24 +5430,24 @@ while.body.252: ; preds = %while.hdr.251 while.exit.253: ; preds = %while.hdr.251 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) ret { ptr, i64 } %callN if.then.254: ; preds = %while.body.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.255 if.merge.255: ; preds = %if.then.254, %while.body.252 %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.515, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.517, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5490,7 +5499,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 9 }, { ptr, i64 } { ptr @str.518, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 9 }, { ptr, i64 } { ptr @str.520, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5509,24 +5518,24 @@ while.body.257: ; preds = %while.hdr.256 while.exit.258: ; preds = %while.hdr.256 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) ret { ptr, i64 } %callN if.then.259: ; preds = %while.body.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 if.merge.260: ; preds = %if.then.259, %while.body.257 %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.523, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.525, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5569,7 +5578,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 4 }, { ptr, i64 } { ptr @str.526, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.527, i64 4 }, { ptr, i64 } { ptr @str.528, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5588,24 +5597,24 @@ while.body.262: ; preds = %while.hdr.261 while.exit.263: ; preds = %while.hdr.261 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 1 }) ret { ptr, i64 } %callN if.then.264: ; preds = %while.body.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.265 if.merge.265: ; preds = %if.then.264, %while.body.262 %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.531, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.533, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5651,7 +5660,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.533, i64 6 }, { ptr, i64 } { ptr @str.534, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.535, i64 6 }, { ptr, i64 } { ptr @str.536, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5670,24 +5679,24 @@ while.body.267: ; preds = %while.hdr.266 while.exit.268: ; preds = %while.hdr.266 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 1 }) ret { ptr, i64 } %callN if.then.269: ; preds = %while.body.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 if.merge.270: ; preds = %if.then.269, %while.body.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.544, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.546, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5769,7 +5778,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.546, i64 6 }, { ptr, i64 } { ptr @str.547, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.548, i64 6 }, { ptr, i64 } { ptr @str.549, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5788,24 +5797,24 @@ while.body.272: ; preds = %while.hdr.271 while.exit.273: ; preds = %while.hdr.271 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 1 }) ret { ptr, i64 } %callN if.then.274: ; preds = %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.275 if.merge.275: ; preds = %if.then.274, %while.body.272 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.554, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.556, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5864,9 +5873,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.561, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.563, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, 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 @@ -5885,8 +5894,8 @@ entry: if.then.283: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.565, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.284 @@ -5905,9 +5914,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.568, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.570, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.566, 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 @@ -5926,8 +5935,8 @@ entry: if.then.285: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -5957,9 +5966,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.578, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.580, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.573, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -5976,8 +5985,8 @@ entry: if.then.287: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.288 @@ -6055,9 +6064,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.589, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.591, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, 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 @@ -6076,8 +6085,8 @@ entry: if.then.289: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.290 @@ -6096,9 +6105,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.600, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.594, 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 @@ -6117,8 +6126,8 @@ entry: if.then.291: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.599, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.292 @@ -6135,7 +6144,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.601, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.603, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6152,12 +6161,12 @@ while.body.302: ; preds = %while.hdr.301 while.exit.303: ; preds = %while.hdr.301 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, i64 1 }) ret { ptr, i64 } %call if.then.304: ; preds = %while.body.302 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 @@ -6186,7 +6195,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.604, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.606, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.306 @@ -6203,12 +6212,12 @@ while.body.307: ; preds = %while.hdr.306 while.exit.308: ; preds = %while.hdr.306 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 1 }) ret { ptr, i64 } %call if.then.309: ; preds = %while.body.307 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.310 @@ -6238,7 +6247,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.607, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.609, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.311 @@ -6255,12 +6264,12 @@ while.body.312: ; preds = %while.hdr.311 while.exit.313: ; preds = %while.hdr.311 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) ret { ptr, i64 } %call if.then.314: ; preds = %while.body.312 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.315 @@ -6288,7 +6297,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.610, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.612, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.316 @@ -6305,12 +6314,12 @@ while.body.317: ; preds = %while.hdr.316 while.exit.318: ; preds = %while.hdr.316 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 1 }) ret { ptr, i64 } %call if.then.319: ; preds = %while.body.317 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.320 @@ -6339,7 +6348,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.613, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.615, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.321 @@ -6356,12 +6365,12 @@ while.body.322: ; preds = %while.hdr.321 while.exit.323: ; preds = %while.hdr.321 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) ret { ptr, i64 } %call if.then.324: ; preds = %while.body.322 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.325 @@ -6390,7 +6399,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.616, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.618, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.326 @@ -6407,12 +6416,12 @@ while.body.327: ; preds = %while.hdr.326 while.exit.328: ; preds = %while.hdr.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 1 }) ret { ptr, i64 } %call if.then.329: ; preds = %while.body.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.330 @@ -6442,7 +6451,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.619, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.621, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.338 @@ -6461,12 +6470,12 @@ while.body.339: ; preds = %while.hdr.338 while.exit.340: ; preds = %while.hdr.338 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) ret { ptr, i64 } %call if.then.341: ; preds = %while.body.339 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.342 @@ -6495,7 +6504,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.622, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.624, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.343 @@ -6514,12 +6523,12 @@ while.body.344: ; preds = %while.hdr.343 while.exit.345: ; preds = %while.hdr.343 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 1 }) ret { ptr, i64 } %call if.then.346: ; preds = %while.body.344 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.347 @@ -6548,7 +6557,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.625, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.627, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.348 @@ -6567,12 +6576,12 @@ while.body.349: ; preds = %while.hdr.348 while.exit.350: ; preds = %while.hdr.348 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.628, i64 1 }) ret { ptr, i64 } %call if.then.351: ; preds = %while.body.349 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.352 @@ -6602,7 +6611,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.628, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.630, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.353 @@ -6621,12 +6630,12 @@ while.body.354: ; preds = %while.hdr.353 while.exit.355: ; preds = %while.hdr.353 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 1 }) ret { ptr, i64 } %call if.then.356: ; preds = %while.body.354 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.630, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.357 @@ -6656,7 +6665,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.631, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.633, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.358 @@ -6675,12 +6684,12 @@ while.body.359: ; preds = %while.hdr.358 while.exit.360: ; preds = %while.hdr.358 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.632, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, i64 1 }) ret { ptr, i64 } %call if.then.361: ; preds = %while.body.359 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.633, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.635, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.362 @@ -6722,12 +6731,12 @@ if.then.396: ; preds = %entry if.else.397: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.635, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 5 }, { ptr, i64 } %callN) br label %if.merge.398 if.merge.398: ; preds = %if.else.397, %if.then.396 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6750,12 +6759,12 @@ if.then.412: ; preds = %entry if.else.413: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 11 }, { ptr, i64 } %callN) br label %if.merge.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6778,12 +6787,12 @@ if.then.415: ; preds = %entry if.else.416: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 4 }, { ptr, i64 } %callN) br label %if.merge.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6806,12 +6815,12 @@ if.then.418: ; preds = %entry if.else.419: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 11 }, { ptr, i64 } %callN) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6834,12 +6843,12 @@ if.then.421: ; preds = %entry if.else.422: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 6 }, { ptr, i64 } %callN) br label %if.merge.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -6861,12 +6870,12 @@ if.then.424: ; preds = %entry if.else.425: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 5 }, { ptr, i64 } %callN) br label %if.merge.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -6889,12 +6898,12 @@ if.then.427: ; preds = %entry if.else.428: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 9 }, { ptr, i64 } %callN) br label %if.merge.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -6917,12 +6926,12 @@ if.then.430: ; preds = %entry if.else.431: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 18 }, { ptr, i64 } %callN) br label %if.merge.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -6945,12 +6954,12 @@ if.then.433: ; preds = %entry if.else.434: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.660, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 5 }, { ptr, i64 } %callN) br label %if.merge.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -6973,12 +6982,12 @@ if.then.436: ; preds = %entry if.else.437: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.662, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { ptr, i64 } %callN) br label %if.merge.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7001,12 +7010,12 @@ if.then.439: ; preds = %entry if.else.440: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 4 }, { ptr, i64 } %callN) br label %if.merge.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7029,12 +7038,12 @@ if.then.442: ; preds = %entry if.else.443: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 9 }, { ptr, i64 } %callN) br label %if.merge.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7057,12 +7066,12 @@ if.then.445: ; preds = %entry if.else.446: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 4 }, { ptr, i64 } %callN) br label %if.merge.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7084,12 +7093,12 @@ if.then.448: ; preds = %entry if.else.449: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 8 }, { ptr, i64 } %callN) br label %if.merge.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7112,12 +7121,12 @@ if.then.451: ; preds = %entry if.else.452: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 6 }, { ptr, i64 } %callN) br label %if.merge.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7139,12 +7148,12 @@ if.then.454: ; preds = %entry if.else.455: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 9 }, { ptr, i64 } %callN) br label %if.merge.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7167,12 +7176,12 @@ if.then.457: ; preds = %entry if.else.458: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 7 }, { ptr, i64 } %callN) br label %if.merge.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7195,12 +7204,12 @@ if.then.460: ; preds = %entry if.else.461: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 5 }, { ptr, i64 } %callN) br label %if.merge.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7223,12 +7232,12 @@ if.then.463: ; preds = %entry if.else.464: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { ptr, i64 } %callN) br label %if.merge.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7251,12 +7260,12 @@ if.then.466: ; preds = %entry if.else.467: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 4 }, { ptr, i64 } %callN) br label %if.merge.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7279,12 +7288,12 @@ if.then.469: ; preds = %entry if.else.470: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { ptr, i64 } %callN) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7307,12 +7316,12 @@ if.then.472: ; preds = %entry if.else.473: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 5 }, { ptr, i64 } %callN) br label %if.merge.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7335,12 +7344,12 @@ if.then.475: ; preds = %entry if.else.476: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 7 }, { ptr, i64 } %callN) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7363,12 +7372,12 @@ if.then.478: ; preds = %entry if.else.479: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 12 }, { ptr, i64 } %callN) br label %if.merge.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7391,12 +7400,12 @@ if.then.481: ; preds = %entry if.else.482: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 6 }, { ptr, i64 } %callN) br label %if.merge.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7419,12 +7428,12 @@ if.then.484: ; preds = %entry if.else.485: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 10 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 10 }, { ptr, i64 } %callN) br label %if.merge.486 if.merge.486: ; preds = %if.else.485, %if.then.484 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -7447,12 +7456,12 @@ if.then.487: ; preds = %entry if.else.488: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 7 }, { ptr, i64 } %callN) br label %if.merge.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -7475,12 +7484,12 @@ if.then.490: ; preds = %entry if.else.491: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 4 }, { ptr, i64 } %callN) br label %if.merge.492 if.merge.492: ; preds = %if.else.491, %if.then.490 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -7503,12 +7512,12 @@ if.then.493: ; preds = %entry if.else.494: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 7 }, { ptr, i64 } %callN) br label %if.merge.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -7531,12 +7540,12 @@ if.then.496: ; preds = %entry if.else.497: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 6 }, { ptr, i64 } %callN) br label %if.merge.498 if.merge.498: ; preds = %if.else.497, %if.then.496 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -7559,12 +7568,12 @@ if.then.499: ; preds = %entry if.else.500: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 5 }, { ptr, i64 } %callN) br label %if.merge.501 if.merge.501: ; preds = %if.else.500, %if.then.499 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -7580,7 +7589,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7604,7 +7613,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.511: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7628,7 +7637,7 @@ entry: br i1 %lnot, label %if.then.512, label %if.merge.513 if.then.512: ; preds = %entry - ret { ptr, i64 } { ptr @str.729, i64 4 } + ret { ptr, i64 } { ptr @str.731, i64 4 } if.merge.513: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7652,7 +7661,7 @@ entry: br i1 %lnot, label %if.then.514, label %if.merge.515 if.then.514: ; preds = %entry - ret { ptr, i64 } { ptr @str.730, i64 4 } + ret { ptr, i64 } { ptr @str.732, i64 4 } if.merge.515: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/1202-ffi-cc-c-large-aggregate.ir b/examples/expected/1202-ffi-cc-c-large-aggregate.ir index 9f95d1b..d856a7d 100644 --- a/examples/expected/1202-ffi-cc-c-large-aggregate.ir +++ b/examples/expected/1202-ffi-cc-c-large-aggregate.ir @@ -12,6 +12,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -130,64 +133,67 @@ declare ptr @any_to_string(ptr, [2 x i64]) #0 declare ptr @build_format(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -363,163 +369,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -717,64 +726,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -804,97 +813,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -933,7 +942,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @accept_c(ptr %0) #0 { diff --git a/examples/expected/1309-ffi-objc-class-method-lowering.ir b/examples/expected/1309-ffi-objc-class-method-lowering.ir index c81d057..594e3aa 100644 --- a/examples/expected/1309-ffi-objc-class-method-lowering.ir +++ b/examples/expected/1309-ffi-objc-class-method-lowering.ir @@ -4,34 +4,34 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @__sx_objc_cstr_dealloc = internal constant [8 x i8] c"dealloc\00" @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.163 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.164 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.165 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.166 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.167 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.168 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.169 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.170 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.171 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.172 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.173 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.174 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.175 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.176 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.177 = private unnamed_addr constant [10 x i8] c"compiled\0A\00", align 1 -@str.178 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.165 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.166 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.168 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.169 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.170 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.171 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.172 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.173 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.174 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.175 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.176 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.177 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.178 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.179 = private unnamed_addr constant [10 x i8] c"compiled\0A\00", align 1 +@str.180 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.181 = private unnamed_addr constant [10 x i8] c"compiled\0A\00", align 1 @OBJC_IVAR_NAME_ = private unnamed_addr constant [11 x i8] c"__sx_state\00" @OBJC_IVAR_TYPE_ = private unnamed_addr constant [3 x i8] c"^v\00" @OBJC_CLASS_NAME_ = private unnamed_addr constant [9 x i8] c"NSObject\00" -@OBJC_CLASS_NAME_.180 = private unnamed_addr constant [6 x i8] c"SxFoo\00" +@OBJC_CLASS_NAME_.182 = private unnamed_addr constant [6 x i8] c"SxFoo\00" @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [5 x i8] c"bump\00" @OBJC_METH_VAR_TYPE_ = private unnamed_addr constant [4 x i8] c"v@:\00" -@OBJC_METH_VAR_NAME_.181 = private unnamed_addr constant [8 x i8] c"dealloc\00" -@OBJC_METH_VAR_TYPE_.182 = private unnamed_addr constant [4 x i8] c"v@:\00" -@OBJC_METH_VAR_NAME_.183 = private unnamed_addr constant [6 x i8] c"alloc\00" -@OBJC_METH_VAR_TYPE_.184 = private unnamed_addr constant [4 x i8] c"@@:\00" +@OBJC_METH_VAR_NAME_.183 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.184 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.185 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.186 = private unnamed_addr constant [4 x i8] c"@@:\00" ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -44,6 +44,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -336,7 +339,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.162, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.164, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -432,7 +435,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.163, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -440,7 +443,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.164, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -450,13 +453,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -464,7 +467,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -478,7 +481,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -486,7 +489,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -497,7 +500,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -554,7 +557,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -562,7 +565,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -573,7 +576,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -593,7 +596,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -601,7 +604,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -612,7 +615,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -622,64 +625,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -855,163 +861,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1209,64 +1218,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1296,97 +1305,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1425,118 +1434,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind define internal void @SxFoo.bump(ptr %0, ptr %1) #0 { @@ -1579,14 +1588,14 @@ entry: define internal void @print__ct_sfeff9eeccd48b824__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.177, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.179, i64 9 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.178, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.180, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 9) @@ -1602,7 +1611,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.179, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.181, i64 9 }) ret { ptr, i64 } %call } @@ -1682,17 +1691,17 @@ declare ptr @class_getInstanceVariable(ptr, ptr) define internal void @__sx_objc_defined_class_init() { entry: %super_cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_) - %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.180, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.182, i64 0) %0 = call i8 @class_addIvar(ptr %cls, ptr @OBJC_IVAR_NAME_, i64 8, i8 3, ptr @OBJC_IVAR_TYPE_) %metacls = call ptr @object_getClass(ptr %cls) %sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_) %1 = call i8 @class_addMethod(ptr %cls, ptr %sel, ptr @__SxFoo_bump_imp, ptr @OBJC_METH_VAR_TYPE_) call void @objc_registerClassPair(ptr %cls) store ptr %cls, ptr @__SxFoo_class, align 8 - %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.181) - %2 = call i8 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.182) - %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.183) - %3 = call i8 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.184) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.183) + %2 = call i8 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.184) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.185) + %3 = call i8 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.186) %iv = call ptr @class_getInstanceVariable(ptr %cls, ptr @OBJC_IVAR_NAME_) store ptr %iv, ptr @__SxFoo_state_ivar, align 8 ret void diff --git a/examples/expected/1314-ffi-objc-class-dealloc-roundtrip.ir b/examples/expected/1314-ffi-objc-class-dealloc-roundtrip.ir index 968a2b2..34bee72 100644 --- a/examples/expected/1314-ffi-objc-class-dealloc-roundtrip.ir +++ b/examples/expected/1314-ffi-objc-class-dealloc-roundtrip.ir @@ -4,50 +4,50 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @__sx_objc_cstr_dealloc = internal constant [8 x i8] c"dealloc\00" @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.163 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.164 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.165 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.166 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.167 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.168 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.169 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.170 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.171 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.172 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.173 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.174 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.175 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.176 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.177 = private unnamed_addr constant [6 x i8] c"SxFoo\00", align 1 -@str.178 = private unnamed_addr constant [8 x i8] c"dealloc\00", align 1 -@str.179 = private unnamed_addr constant [6 x i8] c"alloc\00", align 1 -@str.180 = private unnamed_addr constant [8 x i8] c"release\00", align 1 -@str.181 = private unnamed_addr constant [28 x i8] c"FAIL: SxFoo not registered\0A\00", align 1 -@str.182 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.165 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.166 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.168 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.169 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.170 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.171 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.172 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.173 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.174 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.175 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.176 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.177 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.178 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.179 = private unnamed_addr constant [6 x i8] c"SxFoo\00", align 1 +@str.180 = private unnamed_addr constant [8 x i8] c"dealloc\00", align 1 +@str.181 = private unnamed_addr constant [6 x i8] c"alloc\00", align 1 +@str.182 = private unnamed_addr constant [8 x i8] c"release\00", align 1 @str.183 = private unnamed_addr constant [28 x i8] c"FAIL: SxFoo not registered\0A\00", align 1 -@str.184 = private unnamed_addr constant [27 x i8] c"FAIL: dealloc IMP missing\0A\00", align 1 -@str.185 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.184 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.185 = private unnamed_addr constant [28 x i8] c"FAIL: SxFoo not registered\0A\00", align 1 @str.186 = private unnamed_addr constant [27 x i8] c"FAIL: dealloc IMP missing\0A\00", align 1 -@str.187 = private unnamed_addr constant [28 x i8] c"FAIL: +alloc returned null\0A\00", align 1 -@str.188 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.187 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.188 = private unnamed_addr constant [27 x i8] c"FAIL: dealloc IMP missing\0A\00", align 1 @str.189 = private unnamed_addr constant [28 x i8] c"FAIL: +alloc returned null\0A\00", align 1 -@str.190 = private unnamed_addr constant [36 x i8] c"FAIL: +alloc round 2 returned null\0A\00", align 1 -@str.191 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.190 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.191 = private unnamed_addr constant [28 x i8] c"FAIL: +alloc returned null\0A\00", align 1 @str.192 = private unnamed_addr constant [36 x i8] c"FAIL: +alloc round 2 returned null\0A\00", align 1 -@str.193 = private unnamed_addr constant [13 x i8] c"dealloc: ok\0A\00", align 1 -@str.194 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.193 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.194 = private unnamed_addr constant [36 x i8] c"FAIL: +alloc round 2 returned null\0A\00", align 1 @str.195 = private unnamed_addr constant [13 x i8] c"dealloc: ok\0A\00", align 1 +@str.196 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.197 = private unnamed_addr constant [13 x i8] c"dealloc: ok\0A\00", align 1 @OBJC_IVAR_NAME_ = private unnamed_addr constant [11 x i8] c"__sx_state\00" @OBJC_IVAR_TYPE_ = private unnamed_addr constant [3 x i8] c"^v\00" @OBJC_CLASS_NAME_ = private unnamed_addr constant [9 x i8] c"NSObject\00" -@OBJC_CLASS_NAME_.196 = private unnamed_addr constant [6 x i8] c"SxFoo\00" +@OBJC_CLASS_NAME_.198 = private unnamed_addr constant [6 x i8] c"SxFoo\00" @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [5 x i8] c"bump\00" @OBJC_METH_VAR_TYPE_ = private unnamed_addr constant [4 x i8] c"v@:\00" -@OBJC_METH_VAR_NAME_.197 = private unnamed_addr constant [8 x i8] c"dealloc\00" -@OBJC_METH_VAR_TYPE_.198 = private unnamed_addr constant [4 x i8] c"v@:\00" -@OBJC_METH_VAR_NAME_.199 = private unnamed_addr constant [6 x i8] c"alloc\00" -@OBJC_METH_VAR_TYPE_.200 = private unnamed_addr constant [4 x i8] c"@@:\00" +@OBJC_METH_VAR_NAME_.199 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.200 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.201 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.202 = private unnamed_addr constant [4 x i8] c"@@:\00" ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -60,6 +60,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -352,7 +355,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.162, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.164, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -448,7 +451,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.163, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.164, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -466,13 +469,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -480,7 +483,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -494,7 +497,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -502,7 +505,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -513,7 +516,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -570,7 +573,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -578,7 +581,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -589,7 +592,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -609,7 +612,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -617,7 +620,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -628,7 +631,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -638,64 +641,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -871,163 +877,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1225,64 +1234,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1312,97 +1321,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1441,118 +1450,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -1639,7 +1648,7 @@ entry: %allocaN = alloca ptr, align 8 %allocaN = alloca ptr, align 8 %allocaN = alloca ptr, align 8 - %call = call ptr @objc_getClass(ptr @str.177) + %call = call ptr @objc_getClass(ptr @str.179) store ptr %call, ptr %alloca, align 8 %load = load ptr, ptr %alloca, align 8 %icmp = icmp eq ptr %load, null @@ -1650,7 +1659,7 @@ if.then.0: ; preds = %entry ret i32 1 if.merge.1: ; preds = %entry - %callN = call ptr @sel_registerName(ptr @str.178) + %callN = call ptr @sel_registerName(ptr @str.180) store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %alloca, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -1665,7 +1674,7 @@ if.then.39: ; preds = %if.merge.1 ret i32 1 if.merge.40: ; preds = %if.merge.1 - %callN = call ptr @sel_registerName(ptr @str.179) + %callN = call ptr @sel_registerName(ptr @str.181) store ptr %callN, ptr %allocaN, align 8 store ptr @objc_msgSend, ptr %allocaN, align 8 %loadN = load ptr, ptr %alloca, align 8 @@ -1682,7 +1691,7 @@ if.then.41: ; preds = %if.merge.40 ret i32 1 if.merge.42: ; preds = %if.merge.40 - %callN = call ptr @sel_registerName(ptr @str.180) + %callN = call ptr @sel_registerName(ptr @str.182) store ptr %callN, ptr %allocaN, align 8 store ptr @objc_msgSend, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -1729,14 +1738,14 @@ entry: define internal void @print__ct_s354c93d7643e1bdf__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.181, i64 27 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.183, i64 27 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.182, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.184, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 27) @@ -1752,7 +1761,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.183, i64 27 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.185, i64 27 }) ret { ptr, i64 } %call } @@ -1760,14 +1769,14 @@ entry: define internal void @print__ct_sfe783e2b27a4beff__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.184, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.186, i64 26 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.185, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.187, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 26) @@ -1783,7 +1792,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.186, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.188, i64 26 }) ret { ptr, i64 } %call } @@ -1791,14 +1800,14 @@ entry: define internal void @print__ct_scaebdbbd10c81716__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.187, i64 27 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.189, i64 27 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.188, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.190, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 27) @@ -1814,7 +1823,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.189, i64 27 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.191, i64 27 }) ret { ptr, i64 } %call } @@ -1822,14 +1831,14 @@ entry: define internal void @print__ct_s7c1052877b8cc801__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.190, i64 35 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.192, i64 35 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.191, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.193, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 35) @@ -1845,7 +1854,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_3(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.192, i64 35 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.194, i64 35 }) ret { ptr, i64 } %call } @@ -1853,14 +1862,14 @@ entry: define internal void @print__ct_sed4e79fbcbd67966__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.193, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.195, i64 12 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.194, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.196, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -1876,7 +1885,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_4(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.195, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.197, i64 12 }) ret { ptr, i64 } %call } @@ -1934,17 +1943,17 @@ declare i8 @class_addIvar(ptr, ptr, i64, i8, ptr) define internal void @__sx_objc_defined_class_init() { entry: %super_cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_) - %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.196, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.198, i64 0) %0 = call i8 @class_addIvar(ptr %cls, ptr @OBJC_IVAR_NAME_, i64 8, i8 3, ptr @OBJC_IVAR_TYPE_) %metacls = call ptr @object_getClass(ptr %cls) %sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_) %1 = call i1 @class_addMethod(ptr %cls, ptr %sel, ptr @__SxFoo_bump_imp, ptr @OBJC_METH_VAR_TYPE_) call void @objc_registerClassPair(ptr %cls) store ptr %cls, ptr @__SxFoo_class, align 8 - %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.197) - %2 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.198) - %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.199) - %3 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.200) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.199) + %2 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.200) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.201) + %3 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.202) %iv = call ptr @class_getInstanceVariable(ptr %cls, ptr @OBJC_IVAR_NAME_) store ptr %iv, ptr @__SxFoo_state_ivar, align 8 ret void diff --git a/examples/expected/1319-ffi-objc-property-sx-defined.ir b/examples/expected/1319-ffi-objc-property-sx-defined.ir index 434dc74..a2b4831 100644 --- a/examples/expected/1319-ffi-objc-property-sx-defined.ir +++ b/examples/expected/1319-ffi-objc-property-sx-defined.ir @@ -11,693 +11,693 @@ @OBJC_SELECTOR_REFERENCES_area = internal global ptr null @__sx_objc_cstr_dealloc = internal constant [8 x i8] c"dealloc\00" @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.163 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.164 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.165 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.166 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.167 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.165 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.166 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.167 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.168 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.169 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [175 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.168 = private constant [9 x i8] c"Overflow\00" -@tag.str.169 = private constant [3 x i8] c"Io\00" -@tag.str.170 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.171 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.172 = private constant [10 x i8] c"BadEscape\00" -@tag.str.173 = private constant [10 x i8] c"BadNumber\00" -@tag.str.174 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.175 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.176 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.177 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.178 = private constant [13 x i8] c"MissingValue\00" -@tag.str.179 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.180 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.168, i64 8 }, { ptr, i64 } { ptr @tag.str.169, i64 2 }, { ptr, i64 } { ptr @tag.str.170, i64 15 }, { ptr, i64 } { ptr @tag.str.171, i64 13 }, { ptr, i64 } { ptr @tag.str.172, i64 9 }, { ptr, i64 } { ptr @tag.str.173, i64 9 }, { ptr, i64 } { ptr @tag.str.174, i64 15 }, { ptr, i64 } { ptr @tag.str.175, i64 14 }, { ptr, i64 } { ptr @tag.str.176, i64 14 }, { ptr, i64 } { ptr @tag.str.177, i64 11 }, { ptr, i64 } { ptr @tag.str.178, i64 12 }, { ptr, i64 } { ptr @tag.str.179, i64 15 }, { ptr, i64 } { ptr @tag.str.180, i64 12 }] +@tag.str.170 = private constant [9 x i8] c"Overflow\00" +@tag.str.171 = private constant [3 x i8] c"Io\00" +@tag.str.172 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.173 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.174 = private constant [10 x i8] c"BadEscape\00" +@tag.str.175 = private constant [10 x i8] c"BadNumber\00" +@tag.str.176 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.177 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.178 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.179 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.180 = private constant [13 x i8] c"MissingValue\00" +@tag.str.181 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.182 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.170, i64 8 }, { ptr, i64 } { ptr @tag.str.171, i64 2 }, { ptr, i64 } { ptr @tag.str.172, i64 15 }, { ptr, i64 } { ptr @tag.str.173, i64 13 }, { ptr, i64 } { ptr @tag.str.174, i64 9 }, { ptr, i64 } { ptr @tag.str.175, i64 9 }, { ptr, i64 } { ptr @tag.str.176, i64 15 }, { ptr, i64 } { ptr @tag.str.177, i64 14 }, { ptr, i64 } { ptr @tag.str.178, i64 14 }, { ptr, i64 } { ptr @tag.str.179, i64 11 }, { ptr, i64 } { ptr @tag.str.180, i64 12 }, { ptr, i64 } { ptr @tag.str.181, i64 15 }, { ptr, i64 } { ptr @tag.str.182, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.181 = private constant [5 x i8] c"bool\00" -@tn.str.182 = private constant [3 x i8] c"s8\00" -@tn.str.183 = private constant [4 x i8] c"s16\00" -@tn.str.184 = private constant [4 x i8] c"s32\00" -@tn.str.185 = private constant [4 x i8] c"s64\00" -@tn.str.186 = private constant [3 x i8] c"u8\00" -@tn.str.187 = private constant [4 x i8] c"u16\00" -@tn.str.188 = private constant [4 x i8] c"u32\00" -@tn.str.189 = private constant [4 x i8] c"u64\00" -@tn.str.190 = private constant [4 x i8] c"f32\00" -@tn.str.191 = private constant [4 x i8] c"f64\00" -@tn.str.192 = private constant [7 x i8] c"string\00" -@tn.str.193 = private constant [4 x i8] c"Any\00" -@tn.str.194 = private constant [9 x i8] c"noreturn\00" -@tn.str.195 = private constant [6 x i8] c"isize\00" -@tn.str.196 = private constant [6 x i8] c"usize\00" -@tn.str.197 = private constant [5 x i8] c"void\00" -@tn.str.198 = private constant [6 x i8] c"*void\00" -@tn.str.199 = private constant [16 x i8] c"Source_Location\00" -@tn.str.200 = private constant [11 x i8] c"CAllocator\00" -@tn.str.201 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.202 = private constant [4 x i8] c"GPA\00" -@tn.str.203 = private constant [5 x i8] c"*GPA\00" -@tn.str.204 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.205 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.206 = private constant [10 x i8] c"Allocator\00" -@tn.str.207 = private constant [6 x i8] c"Arena\00" -@tn.str.208 = private constant [7 x i8] c"*Arena\00" -@tn.str.209 = private constant [6 x i8] c"[*]u8\00" -@tn.str.210 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.211 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.212 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.213 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.214 = private constant [8 x i8] c"Context\00" -@tn.str.215 = private constant [7 x i8] c"[4]s64\00" -@tn.str.216 = private constant [9 x i8] c"[]string\00" -@tn.str.217 = private constant [9 x i8] c"OpenMode\00" -@tn.str.218 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.219 = private constant [5 x i8] c"File\00" -@tn.str.220 = private constant [6 x i8] c"*File\00" -@tn.str.221 = private constant [6 x i8] c"?File\00" -@tn.str.222 = private constant [8 x i8] c"?string\00" -@tn.str.223 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.224 = private constant [4 x i8] c"*u8\00" -@tn.str.225 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.226 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.227 = private constant [5 x i8] c"*s32\00" -@tn.str.228 = private constant [9 x i8] c"SockAddr\00" -@tn.str.229 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.230 = private constant [5 x i8] c"*u32\00" -@tn.str.231 = private constant [10 x i8] c"JsonError\00" -@tn.str.232 = private constant [6 x i8] c"Array\00" -@tn.str.233 = private constant [7 x i8] c"Object\00" -@tn.str.234 = private constant [6 x i8] c"Value\00" -@tn.str.235 = private constant [7 x i8] c"Member\00" -@tn.str.236 = private constant [9 x i8] c"[*]Value\00" -@tn.str.237 = private constant [7 x i8] c"*Array\00" -@tn.str.238 = private constant [10 x i8] c"[*]Member\00" -@tn.str.239 = private constant [8 x i8] c"*Object\00" -@tn.str.240 = private constant [5 x i8] c"[]u8\00" -@tn.str.241 = private constant [5 x i8] c"Sink\00" -@tn.str.242 = private constant [6 x i8] c"*Sink\00" -@tn.str.243 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.244 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.245 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.246 = private constant [7 x i8] c"Parser\00" -@tn.str.247 = private constant [8 x i8] c"*Parser\00" -@tn.str.248 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.249 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.250 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.251 = private constant [13 x i8] c"Architecture\00" -@tn.str.252 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.253 = private constant [11 x i8] c"() -> bool\00" -@tn.str.254 = private constant [5 x i8] c"*s64\00" -@tn.str.255 = private constant [9 x i8] c"CliError\00" -@tn.str.256 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.257 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.258 = private constant [8 x i8] c"Command\00" -@tn.str.259 = private constant [10 x i8] c"FlagValue\00" -@tn.str.260 = private constant [5 x i8] c"Diag\00" -@tn.str.261 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.262 = private constant [7 x i8] c"Parsed\00" -@tn.str.263 = private constant [8 x i8] c"*Parsed\00" -@tn.str.264 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.265 = private constant [10 x i8] c"[]Command\00" -@tn.str.266 = private constant [6 x i8] c"*Diag\00" -@tn.str.267 = private constant [7 x i8] c"[8]s64\00" -@tn.str.268 = private constant [7 x i8] c"[64]u8\00" -@tn.str.269 = private constant [7 x i8] c"Sha256\00" -@tn.str.270 = private constant [8 x i8] c"*Sha256\00" -@tn.str.271 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.272 = private constant [8 x i8] c"[64]s64\00" -@tn.str.273 = private constant [9 x i8] c"NSString\00" -@tn.str.274 = private constant [10 x i8] c"*NSString\00" -@tn.str.275 = private constant [10 x i8] c"Closure()\00" -@tn.str.276 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.277 = private constant [7 x i8] c"**void\00" -@tn.str.278 = private constant [6 x i8] c"SxBox\00" -@tn.str.279 = private constant [7 x i8] c"*SxBox\00" -@tn.str.280 = private constant [13 x i8] c"__SxBoxState\00" -@tn.str.281 = private constant [8 x i8] c"**SxBox\00" -@tn.str.282 = private constant [8 x i8] c"*string\00" -@tn.str.283 = private constant [6 x i8] c"[]Any\00" -@tn.str.284 = private constant [5 x i8] c"*Any\00" -@tn.str.285 = private constant [7 x i8] c"*[]Any\00" -@tn.str.286 = private constant [6 x i8] c"*bool\00" -@tn.str.287 = private constant [7 x i8] c"[1]Any\00" -@tn.str.288 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.289 = private constant [7 x i8] c"[3]Any\00" -@tn.str.290 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.291 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.292 = private constant [5 x i8] c"*f64\00" -@tn.str.293 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.294 = private constant [11 x i8] c"*Allocator\00" -@tn.str.295 = private constant [9 x i8] c"*Context\00" -@tn.str.296 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.297 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.298 = private constant [8 x i8] c"*Member\00" -@tn.str.299 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.300 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.301 = private constant [9 x i8] c"*Command\00" -@tn.str.302 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.303 = private constant [14 x i8] c"*__SxBoxState\00" -@tn.str.304 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.305 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.306 = private constant [7 x i8] c"*Value\00" -@tn.str.307 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.308 = private constant [14 x i8] c"*Architecture\00" -@tn.str.309 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.310 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.311 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.312 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.313 = private constant [10 x i8] c"*[]string\00" -@tn.str.314 = private constant [6 x i8] c"*[]u8\00" -@tn.str.315 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.316 = private constant [11 x i8] c"*[]Command\00" -@tn.str.317 = private constant [6 x i8] c"**GPA\00" -@tn.str.318 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.319 = private constant [8 x i8] c"**Arena\00" -@tn.str.320 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.321 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.322 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.323 = private constant [7 x i8] c"**File\00" -@tn.str.324 = private constant [5 x i8] c"**u8\00" -@tn.str.325 = private constant [6 x i8] c"**s32\00" -@tn.str.326 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.327 = private constant [6 x i8] c"**u32\00" -@tn.str.328 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.329 = private constant [8 x i8] c"**Array\00" -@tn.str.330 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.331 = private constant [9 x i8] c"**Object\00" -@tn.str.332 = private constant [7 x i8] c"**Sink\00" -@tn.str.333 = private constant [9 x i8] c"**Parser\00" -@tn.str.334 = private constant [6 x i8] c"**s64\00" -@tn.str.335 = private constant [9 x i8] c"**Parsed\00" -@tn.str.336 = private constant [7 x i8] c"**Diag\00" -@tn.str.337 = private constant [9 x i8] c"**Sha256\00" -@tn.str.338 = private constant [11 x i8] c"**NSString\00" -@tn.str.339 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.340 = private constant [8 x i8] c"***void\00" -@tn.str.341 = private constant [9 x i8] c"***SxBox\00" -@tn.str.342 = private constant [9 x i8] c"**string\00" -@tn.str.343 = private constant [6 x i8] c"**Any\00" -@tn.str.344 = private constant [8 x i8] c"**[]Any\00" -@tn.str.345 = private constant [7 x i8] c"**bool\00" -@tn.str.346 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.347 = private constant [9 x i8] c"**[3]Any\00" -@tn.str.348 = private constant [7 x i8] c"*?File\00" -@tn.str.349 = private constant [9 x i8] c"*?string\00" -@tn.str.350 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.351 = private constant [9 x i8] c"*?[64]u8\00" -@tn.str.352 = private constant [16 x i8] c"__sx_objc_super\00" -@tn.str.353 = private constant [17 x i8] c"*__sx_objc_super\00" -@tn.str.354 = private constant [6 x i8] c"[8]u8\00" -@__sx_type_names = private constant [175 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.181, i64 4 }, { ptr, i64 } { ptr @tn.str.182, i64 2 }, { ptr, i64 } { ptr @tn.str.183, i64 3 }, { ptr, i64 } { ptr @tn.str.184, i64 3 }, { ptr, i64 } { ptr @tn.str.185, i64 3 }, { ptr, i64 } { ptr @tn.str.186, i64 2 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 3 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 6 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 8 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 5 }, { ptr, i64 } { ptr @tn.str.197, i64 4 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 15 }, { ptr, i64 } { ptr @tn.str.200, i64 10 }, { ptr, i64 } { ptr @tn.str.201, i64 11 }, { ptr, i64 } { ptr @tn.str.202, i64 3 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 10 }, { ptr, i64 } { ptr @tn.str.205, i64 11 }, { ptr, i64 } { ptr @tn.str.206, i64 9 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 6 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 8 }, { ptr, i64 } { ptr @tn.str.211, i64 9 }, { ptr, i64 } { ptr @tn.str.212, i64 17 }, { ptr, i64 } { ptr @tn.str.213, i64 18 }, { ptr, i64 } { ptr @tn.str.214, i64 7 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 8 }, { ptr, i64 } { ptr @tn.str.217, i64 8 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 5 }, { ptr, i64 } { ptr @tn.str.221, i64 5 }, { ptr, i64 } { ptr @tn.str.222, i64 7 }, { ptr, i64 } { ptr @tn.str.223, i64 10 }, { ptr, i64 } { ptr @tn.str.224, i64 3 }, { ptr, i64 } { ptr @tn.str.225, i64 13 }, { ptr, i64 } { ptr @tn.str.226, i64 14 }, { ptr, i64 } { ptr @tn.str.227, i64 4 }, { ptr, i64 } { ptr @tn.str.228, i64 8 }, { ptr, i64 } { ptr @tn.str.229, i64 9 }, { ptr, i64 } { ptr @tn.str.230, i64 4 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 5 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 5 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 8 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 9 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 5 }, { ptr, i64 } { ptr @tn.str.243, i64 16 }, { ptr, i64 } { ptr @tn.str.244, i64 14 }, { ptr, i64 } { ptr @tn.str.245, i64 21 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 24 }, { ptr, i64 } { ptr @tn.str.249, i64 23 }, { ptr, i64 } { ptr @tn.str.250, i64 15 }, { ptr, i64 } { ptr @tn.str.251, i64 12 }, { ptr, i64 } { ptr @tn.str.252, i64 12 }, { ptr, i64 } { ptr @tn.str.253, i64 10 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 8 }, { ptr, i64 } { ptr @tn.str.257, i64 10 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 4 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 6 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 18 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 5 }, { ptr, i64 } { ptr @tn.str.267, i64 6 }, { ptr, i64 } { ptr @tn.str.268, i64 6 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 7 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 9 }, { ptr, i64 } { ptr @tn.str.276, i64 12 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 12 }, { ptr, i64 } { ptr @tn.str.281, i64 7 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 4 }, { ptr, i64 } { ptr @tn.str.285, i64 6 }, { ptr, i64 } { ptr @tn.str.286, i64 5 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 7 }, { ptr, i64 } { ptr @tn.str.292, i64 4 }, { ptr, i64 } { ptr @tn.str.293, i64 16 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 11 }, { ptr, i64 } { ptr @tn.str.297, i64 14 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 13 }, { ptr, i64 } { ptr @tn.str.300, i64 9 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 10 }, { ptr, i64 } { ptr @tn.str.303, i64 13 }, { ptr, i64 } { ptr @tn.str.304, i64 9 }, { ptr, i64 } { ptr @tn.str.305, i64 9 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 16 }, { ptr, i64 } { ptr @tn.str.308, i64 13 }, { ptr, i64 } { ptr @tn.str.309, i64 14 }, { ptr, i64 } { ptr @tn.str.310, i64 7 }, { ptr, i64 } { ptr @tn.str.311, i64 7 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 9 }, { ptr, i64 } { ptr @tn.str.314, i64 5 }, { ptr, i64 } { ptr @tn.str.315, i64 11 }, { ptr, i64 } { ptr @tn.str.316, i64 10 }, { ptr, i64 } { ptr @tn.str.317, i64 5 }, { ptr, i64 } { ptr @tn.str.318, i64 12 }, { ptr, i64 } { ptr @tn.str.319, i64 7 }, { ptr, i64 } { ptr @tn.str.320, i64 6 }, { ptr, i64 } { ptr @tn.str.321, i64 10 }, { ptr, i64 } { ptr @tn.str.322, i64 19 }, { ptr, i64 } { ptr @tn.str.323, i64 6 }, { ptr, i64 } { ptr @tn.str.324, i64 4 }, { ptr, i64 } { ptr @tn.str.325, i64 5 }, { ptr, i64 } { ptr @tn.str.326, i64 10 }, { ptr, i64 } { ptr @tn.str.327, i64 5 }, { ptr, i64 } { ptr @tn.str.328, i64 9 }, { ptr, i64 } { ptr @tn.str.329, i64 7 }, { ptr, i64 } { ptr @tn.str.330, i64 10 }, { ptr, i64 } { ptr @tn.str.331, i64 8 }, { ptr, i64 } { ptr @tn.str.332, i64 6 }, { ptr, i64 } { ptr @tn.str.333, i64 8 }, { ptr, i64 } { ptr @tn.str.334, i64 5 }, { ptr, i64 } { ptr @tn.str.335, i64 8 }, { ptr, i64 } { ptr @tn.str.336, i64 6 }, { ptr, i64 } { ptr @tn.str.337, i64 8 }, { ptr, i64 } { ptr @tn.str.338, i64 10 }, { ptr, i64 } { ptr @tn.str.339, i64 13 }, { ptr, i64 } { ptr @tn.str.340, i64 7 }, { ptr, i64 } { ptr @tn.str.341, i64 8 }, { ptr, i64 } { ptr @tn.str.342, i64 8 }, { ptr, i64 } { ptr @tn.str.343, i64 5 }, { ptr, i64 } { ptr @tn.str.344, i64 7 }, { ptr, i64 } { ptr @tn.str.345, i64 6 }, { ptr, i64 } { ptr @tn.str.346, i64 8 }, { ptr, i64 } { ptr @tn.str.347, i64 8 }, { ptr, i64 } { ptr @tn.str.348, i64 6 }, { ptr, i64 } { ptr @tn.str.349, i64 8 }, { ptr, i64 } { ptr @tn.str.350, i64 15 }, { ptr, i64 } { ptr @tn.str.351, i64 8 }, { ptr, i64 } { ptr @tn.str.352, i64 15 }, { ptr, i64 } { ptr @tn.str.353, i64 16 }, { ptr, i64 } { ptr @tn.str.354, i64 5 }] -@str.355 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.356 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.183 = private constant [5 x i8] c"bool\00" +@tn.str.184 = private constant [3 x i8] c"s8\00" +@tn.str.185 = private constant [4 x i8] c"s16\00" +@tn.str.186 = private constant [4 x i8] c"s32\00" +@tn.str.187 = private constant [4 x i8] c"s64\00" +@tn.str.188 = private constant [3 x i8] c"u8\00" +@tn.str.189 = private constant [4 x i8] c"u16\00" +@tn.str.190 = private constant [4 x i8] c"u32\00" +@tn.str.191 = private constant [4 x i8] c"u64\00" +@tn.str.192 = private constant [4 x i8] c"f32\00" +@tn.str.193 = private constant [4 x i8] c"f64\00" +@tn.str.194 = private constant [7 x i8] c"string\00" +@tn.str.195 = private constant [4 x i8] c"Any\00" +@tn.str.196 = private constant [9 x i8] c"noreturn\00" +@tn.str.197 = private constant [6 x i8] c"isize\00" +@tn.str.198 = private constant [6 x i8] c"usize\00" +@tn.str.199 = private constant [5 x i8] c"void\00" +@tn.str.200 = private constant [6 x i8] c"*void\00" +@tn.str.201 = private constant [16 x i8] c"Source_Location\00" +@tn.str.202 = private constant [10 x i8] c"Allocator\00" +@tn.str.203 = private constant [11 x i8] c"CAllocator\00" +@tn.str.204 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.205 = private constant [4 x i8] c"GPA\00" +@tn.str.206 = private constant [5 x i8] c"*GPA\00" +@tn.str.207 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.208 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.209 = private constant [6 x i8] c"Arena\00" +@tn.str.210 = private constant [7 x i8] c"*Arena\00" +@tn.str.211 = private constant [6 x i8] c"[*]u8\00" +@tn.str.212 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.213 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.214 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.215 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.216 = private constant [8 x i8] c"Context\00" +@tn.str.217 = private constant [7 x i8] c"[4]s64\00" +@tn.str.218 = private constant [9 x i8] c"[]string\00" +@tn.str.219 = private constant [9 x i8] c"OpenMode\00" +@tn.str.220 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.221 = private constant [5 x i8] c"File\00" +@tn.str.222 = private constant [6 x i8] c"*File\00" +@tn.str.223 = private constant [6 x i8] c"?File\00" +@tn.str.224 = private constant [8 x i8] c"?string\00" +@tn.str.225 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.226 = private constant [4 x i8] c"*u8\00" +@tn.str.227 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.228 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.229 = private constant [5 x i8] c"*s32\00" +@tn.str.230 = private constant [9 x i8] c"SockAddr\00" +@tn.str.231 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.232 = private constant [5 x i8] c"*u32\00" +@tn.str.233 = private constant [10 x i8] c"JsonError\00" +@tn.str.234 = private constant [6 x i8] c"Array\00" +@tn.str.235 = private constant [7 x i8] c"Object\00" +@tn.str.236 = private constant [6 x i8] c"Value\00" +@tn.str.237 = private constant [7 x i8] c"Member\00" +@tn.str.238 = private constant [9 x i8] c"[*]Value\00" +@tn.str.239 = private constant [7 x i8] c"*Array\00" +@tn.str.240 = private constant [10 x i8] c"[*]Member\00" +@tn.str.241 = private constant [8 x i8] c"*Object\00" +@tn.str.242 = private constant [5 x i8] c"[]u8\00" +@tn.str.243 = private constant [5 x i8] c"Sink\00" +@tn.str.244 = private constant [6 x i8] c"*Sink\00" +@tn.str.245 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.246 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.247 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.248 = private constant [7 x i8] c"Parser\00" +@tn.str.249 = private constant [8 x i8] c"*Parser\00" +@tn.str.250 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.251 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.252 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.253 = private constant [13 x i8] c"Architecture\00" +@tn.str.254 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.255 = private constant [11 x i8] c"() -> bool\00" +@tn.str.256 = private constant [5 x i8] c"*s64\00" +@tn.str.257 = private constant [9 x i8] c"CliError\00" +@tn.str.258 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.259 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.260 = private constant [8 x i8] c"Command\00" +@tn.str.261 = private constant [10 x i8] c"FlagValue\00" +@tn.str.262 = private constant [5 x i8] c"Diag\00" +@tn.str.263 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.264 = private constant [7 x i8] c"Parsed\00" +@tn.str.265 = private constant [8 x i8] c"*Parsed\00" +@tn.str.266 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.267 = private constant [10 x i8] c"[]Command\00" +@tn.str.268 = private constant [6 x i8] c"*Diag\00" +@tn.str.269 = private constant [7 x i8] c"[8]s64\00" +@tn.str.270 = private constant [7 x i8] c"[64]u8\00" +@tn.str.271 = private constant [7 x i8] c"Sha256\00" +@tn.str.272 = private constant [8 x i8] c"*Sha256\00" +@tn.str.273 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.274 = private constant [8 x i8] c"[64]s64\00" +@tn.str.275 = private constant [9 x i8] c"NSString\00" +@tn.str.276 = private constant [10 x i8] c"*NSString\00" +@tn.str.277 = private constant [10 x i8] c"Closure()\00" +@tn.str.278 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.279 = private constant [7 x i8] c"**void\00" +@tn.str.280 = private constant [6 x i8] c"SxBox\00" +@tn.str.281 = private constant [7 x i8] c"*SxBox\00" +@tn.str.282 = private constant [13 x i8] c"__SxBoxState\00" +@tn.str.283 = private constant [8 x i8] c"**SxBox\00" +@tn.str.284 = private constant [8 x i8] c"*string\00" +@tn.str.285 = private constant [6 x i8] c"[]Any\00" +@tn.str.286 = private constant [5 x i8] c"*Any\00" +@tn.str.287 = private constant [7 x i8] c"*[]Any\00" +@tn.str.288 = private constant [6 x i8] c"*bool\00" +@tn.str.289 = private constant [7 x i8] c"[1]Any\00" +@tn.str.290 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.291 = private constant [7 x i8] c"[3]Any\00" +@tn.str.292 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.293 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.294 = private constant [5 x i8] c"*f64\00" +@tn.str.295 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.296 = private constant [11 x i8] c"*Allocator\00" +@tn.str.297 = private constant [9 x i8] c"*Context\00" +@tn.str.298 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.299 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.300 = private constant [8 x i8] c"*Member\00" +@tn.str.301 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.302 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.303 = private constant [9 x i8] c"*Command\00" +@tn.str.304 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.305 = private constant [14 x i8] c"*__SxBoxState\00" +@tn.str.306 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.307 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.308 = private constant [7 x i8] c"*Value\00" +@tn.str.309 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.310 = private constant [14 x i8] c"*Architecture\00" +@tn.str.311 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.312 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.313 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.314 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.315 = private constant [10 x i8] c"*[]string\00" +@tn.str.316 = private constant [6 x i8] c"*[]u8\00" +@tn.str.317 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.318 = private constant [11 x i8] c"*[]Command\00" +@tn.str.319 = private constant [6 x i8] c"**GPA\00" +@tn.str.320 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.321 = private constant [8 x i8] c"**Arena\00" +@tn.str.322 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.323 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.324 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.325 = private constant [7 x i8] c"**File\00" +@tn.str.326 = private constant [5 x i8] c"**u8\00" +@tn.str.327 = private constant [6 x i8] c"**s32\00" +@tn.str.328 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.329 = private constant [6 x i8] c"**u32\00" +@tn.str.330 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.331 = private constant [8 x i8] c"**Array\00" +@tn.str.332 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.333 = private constant [9 x i8] c"**Object\00" +@tn.str.334 = private constant [7 x i8] c"**Sink\00" +@tn.str.335 = private constant [9 x i8] c"**Parser\00" +@tn.str.336 = private constant [6 x i8] c"**s64\00" +@tn.str.337 = private constant [9 x i8] c"**Parsed\00" +@tn.str.338 = private constant [7 x i8] c"**Diag\00" +@tn.str.339 = private constant [9 x i8] c"**Sha256\00" +@tn.str.340 = private constant [11 x i8] c"**NSString\00" +@tn.str.341 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.342 = private constant [8 x i8] c"***void\00" +@tn.str.343 = private constant [9 x i8] c"***SxBox\00" +@tn.str.344 = private constant [9 x i8] c"**string\00" +@tn.str.345 = private constant [6 x i8] c"**Any\00" +@tn.str.346 = private constant [8 x i8] c"**[]Any\00" +@tn.str.347 = private constant [7 x i8] c"**bool\00" +@tn.str.348 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.349 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.350 = private constant [7 x i8] c"*?File\00" +@tn.str.351 = private constant [9 x i8] c"*?string\00" +@tn.str.352 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.353 = private constant [9 x i8] c"*?[64]u8\00" +@tn.str.354 = private constant [16 x i8] c"__sx_objc_super\00" +@tn.str.355 = private constant [17 x i8] c"*__sx_objc_super\00" +@tn.str.356 = private constant [6 x i8] c"[8]u8\00" +@__sx_type_names = private constant [175 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.183, i64 4 }, { ptr, i64 } { ptr @tn.str.184, i64 2 }, { ptr, i64 } { ptr @tn.str.185, i64 3 }, { ptr, i64 } { ptr @tn.str.186, i64 3 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 2 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 3 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 6 }, { ptr, i64 } { ptr @tn.str.195, i64 3 }, { ptr, i64 } { ptr @tn.str.196, i64 8 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 4 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 15 }, { ptr, i64 } { ptr @tn.str.202, i64 9 }, { ptr, i64 } { ptr @tn.str.203, i64 10 }, { ptr, i64 } { ptr @tn.str.204, i64 11 }, { ptr, i64 } { ptr @tn.str.205, i64 3 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 10 }, { ptr, i64 } { ptr @tn.str.208, i64 11 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 6 }, { ptr, i64 } { ptr @tn.str.211, i64 5 }, { ptr, i64 } { ptr @tn.str.212, i64 8 }, { ptr, i64 } { ptr @tn.str.213, i64 9 }, { ptr, i64 } { ptr @tn.str.214, i64 17 }, { ptr, i64 } { ptr @tn.str.215, i64 18 }, { ptr, i64 } { ptr @tn.str.216, i64 7 }, { ptr, i64 } { ptr @tn.str.217, i64 6 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 4 }, { ptr, i64 } { ptr @tn.str.222, i64 5 }, { ptr, i64 } { ptr @tn.str.223, i64 5 }, { ptr, i64 } { ptr @tn.str.224, i64 7 }, { ptr, i64 } { ptr @tn.str.225, i64 10 }, { ptr, i64 } { ptr @tn.str.226, i64 3 }, { ptr, i64 } { ptr @tn.str.227, i64 13 }, { ptr, i64 } { ptr @tn.str.228, i64 14 }, { ptr, i64 } { ptr @tn.str.229, i64 4 }, { ptr, i64 } { ptr @tn.str.230, i64 8 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 4 }, { ptr, i64 } { ptr @tn.str.233, i64 9 }, { ptr, i64 } { ptr @tn.str.234, i64 5 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 5 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 8 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 9 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 5 }, { ptr, i64 } { ptr @tn.str.245, i64 16 }, { ptr, i64 } { ptr @tn.str.246, i64 14 }, { ptr, i64 } { ptr @tn.str.247, i64 21 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 24 }, { ptr, i64 } { ptr @tn.str.251, i64 23 }, { ptr, i64 } { ptr @tn.str.252, i64 15 }, { ptr, i64 } { ptr @tn.str.253, i64 12 }, { ptr, i64 } { ptr @tn.str.254, i64 12 }, { ptr, i64 } { ptr @tn.str.255, i64 10 }, { ptr, i64 } { ptr @tn.str.256, i64 4 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 8 }, { ptr, i64 } { ptr @tn.str.259, i64 10 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 4 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 6 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 18 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 5 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 6 }, { ptr, i64 } { ptr @tn.str.271, i64 6 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 7 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 8 }, { ptr, i64 } { ptr @tn.str.276, i64 9 }, { ptr, i64 } { ptr @tn.str.277, i64 9 }, { ptr, i64 } { ptr @tn.str.278, i64 12 }, { ptr, i64 } { ptr @tn.str.279, i64 6 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 12 }, { ptr, i64 } { ptr @tn.str.283, i64 7 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 5 }, { ptr, i64 } { ptr @tn.str.286, i64 4 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 7 }, { ptr, i64 } { ptr @tn.str.294, i64 4 }, { ptr, i64 } { ptr @tn.str.295, i64 16 }, { ptr, i64 } { ptr @tn.str.296, i64 10 }, { ptr, i64 } { ptr @tn.str.297, i64 8 }, { ptr, i64 } { ptr @tn.str.298, i64 11 }, { ptr, i64 } { ptr @tn.str.299, i64 14 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 13 }, { ptr, i64 } { ptr @tn.str.302, i64 9 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 10 }, { ptr, i64 } { ptr @tn.str.305, i64 13 }, { ptr, i64 } { ptr @tn.str.306, i64 9 }, { ptr, i64 } { ptr @tn.str.307, i64 9 }, { ptr, i64 } { ptr @tn.str.308, i64 6 }, { ptr, i64 } { ptr @tn.str.309, i64 16 }, { ptr, i64 } { ptr @tn.str.310, i64 13 }, { ptr, i64 } { ptr @tn.str.311, i64 14 }, { ptr, i64 } { ptr @tn.str.312, i64 7 }, { ptr, i64 } { ptr @tn.str.313, i64 7 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { ptr, i64 } { ptr @tn.str.315, i64 9 }, { ptr, i64 } { ptr @tn.str.316, i64 5 }, { ptr, i64 } { ptr @tn.str.317, i64 11 }, { ptr, i64 } { ptr @tn.str.318, i64 10 }, { ptr, i64 } { ptr @tn.str.319, i64 5 }, { ptr, i64 } { ptr @tn.str.320, i64 12 }, { ptr, i64 } { ptr @tn.str.321, i64 7 }, { ptr, i64 } { ptr @tn.str.322, i64 6 }, { ptr, i64 } { ptr @tn.str.323, i64 10 }, { ptr, i64 } { ptr @tn.str.324, i64 19 }, { ptr, i64 } { ptr @tn.str.325, i64 6 }, { ptr, i64 } { ptr @tn.str.326, i64 4 }, { ptr, i64 } { ptr @tn.str.327, i64 5 }, { ptr, i64 } { ptr @tn.str.328, i64 10 }, { ptr, i64 } { ptr @tn.str.329, i64 5 }, { ptr, i64 } { ptr @tn.str.330, i64 9 }, { ptr, i64 } { ptr @tn.str.331, i64 7 }, { ptr, i64 } { ptr @tn.str.332, i64 10 }, { ptr, i64 } { ptr @tn.str.333, i64 8 }, { ptr, i64 } { ptr @tn.str.334, i64 6 }, { ptr, i64 } { ptr @tn.str.335, i64 8 }, { ptr, i64 } { ptr @tn.str.336, i64 5 }, { ptr, i64 } { ptr @tn.str.337, i64 8 }, { ptr, i64 } { ptr @tn.str.338, i64 6 }, { ptr, i64 } { ptr @tn.str.339, i64 8 }, { ptr, i64 } { ptr @tn.str.340, i64 10 }, { ptr, i64 } { ptr @tn.str.341, i64 13 }, { ptr, i64 } { ptr @tn.str.342, i64 7 }, { ptr, i64 } { ptr @tn.str.343, i64 8 }, { ptr, i64 } { ptr @tn.str.344, i64 8 }, { ptr, i64 } { ptr @tn.str.345, i64 5 }, { ptr, i64 } { ptr @tn.str.346, i64 7 }, { ptr, i64 } { ptr @tn.str.347, i64 6 }, { ptr, i64 } { ptr @tn.str.348, i64 8 }, { ptr, i64 } { ptr @tn.str.349, i64 8 }, { ptr, i64 } { ptr @tn.str.350, i64 6 }, { ptr, i64 } { ptr @tn.str.351, i64 8 }, { ptr, i64 } { ptr @tn.str.352, i64 15 }, { ptr, i64 } { ptr @tn.str.353, i64 8 }, { ptr, i64 } { ptr @tn.str.354, i64 15 }, { ptr, i64 } { ptr @tn.str.355, i64 16 }, { ptr, i64 } { ptr @tn.str.356, i64 5 }] @str.357 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.358 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.359 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.360 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.361 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.362 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.363 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.364 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.365 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.366 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.367 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.369 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.370 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.371 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.372 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.373 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.374 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.375 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.376 = private unnamed_addr constant [6 x i8] c"SxBox\00", align 1 -@str.377 = private unnamed_addr constant [9 x i8] c"setArea:\00", align 1 -@str.378 = private unnamed_addr constant [31 x i8] c"FAIL: width/height round-trip\0A\00", align 1 -@str.379 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.361 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.362 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.363 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.364 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.366 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.367 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.368 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.369 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.371 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.372 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.373 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.374 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.375 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.376 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.377 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.378 = private unnamed_addr constant [6 x i8] c"SxBox\00", align 1 +@str.379 = private unnamed_addr constant [9 x i8] c"setArea:\00", align 1 @str.380 = private unnamed_addr constant [31 x i8] c"FAIL: width/height round-trip\0A\00", align 1 -@str.381 = private unnamed_addr constant [31 x i8] c"FAIL: area expected 0, got {}\0A\00", align 1 -@str.382 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.381 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.382 = private unnamed_addr constant [31 x i8] c"FAIL: width/height round-trip\0A\00", align 1 @str.383 = private unnamed_addr constant [31 x i8] c"FAIL: area expected 0, got {}\0A\00", align 1 -@str.384 = private unnamed_addr constant [52 x i8] c"FAIL: setArea: should not be registered (readonly)\0A\00", align 1 -@str.385 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.384 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.385 = private unnamed_addr constant [31 x i8] c"FAIL: area expected 0, got {}\0A\00", align 1 @str.386 = private unnamed_addr constant [52 x i8] c"FAIL: setArea: should not be registered (readonly)\0A\00", align 1 -@str.387 = private unnamed_addr constant [29 x i8] c"property: w={} h={} area={}\0A\00", align 1 -@str.388 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.387 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.388 = private unnamed_addr constant [52 x i8] c"FAIL: setArea: should not be registered (readonly)\0A\00", align 1 @str.389 = private unnamed_addr constant [29 x i8] c"property: w={} h={} area={}\0A\00", align 1 -@str.390 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.390 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.391 = private unnamed_addr constant [29 x i8] c"property: w={} h={} area={}\0A\00", align 1 +@str.392 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.393 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.394 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.395 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.394 = private constant [5 x i8] c"line\00" -@fld.str.395 = private constant [4 x i8] c"col\00" -@fld.str.396 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.394, i64 4 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }, { ptr, i64 } { ptr @fld.str.396, i64 4 }] -@str.397 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.398 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.399 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.400 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.401 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.402 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.403 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.404 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.405 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.406 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.407 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.408 = private constant [12 x i8] c"alloc_count\00" -@field_names.409 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 11 }] -@str.410 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.411 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.412 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.413 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.414 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.415 = private constant [5 x i8] c"next\00" -@fld.str.416 = private constant [4 x i8] c"cap\00" -@field_names.417 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 4 }, { ptr, i64 } { ptr @fld.str.416, i64 3 }] -@str.418 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.419 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.420 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.421 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.422 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.423 = private constant [4 x i8] c"ctx\00" -@fld.str.424 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.425 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.426 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 3 }, { ptr, i64 } { ptr @fld.str.424, i64 11 }, { ptr, i64 } { ptr @fld.str.425, i64 13 }] -@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.428 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.430 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.431 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.432 = private constant [6 x i8] c"first\00" -@fld.str.433 = private constant [10 x i8] c"end_index\00" -@fld.str.434 = private constant [7 x i8] c"parent\00" -@field_names.435 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 5 }, { ptr, i64 } { ptr @fld.str.433, i64 9 }, { ptr, i64 } { ptr @fld.str.434, i64 6 }] -@str.436 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.437 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.439 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.440 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.441 = private constant [4 x i8] c"buf\00" -@fld.str.442 = private constant [4 x i8] c"len\00" -@fld.str.443 = private constant [4 x i8] c"pos\00" -@field_names.444 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.441, i64 3 }, { ptr, i64 } { ptr @fld.str.442, i64 3 }, { ptr, i64 } { ptr @fld.str.443, i64 3 }] -@str.445 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.446 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.447 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.449 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.450 = private constant [7 x i8] c"parent\00" -@fld.str.451 = private constant [12 x i8] c"alloc_count\00" -@fld.str.452 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.453 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.454 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.450, i64 6 }, { ptr, i64 } { ptr @fld.str.451, i64 11 }, { ptr, i64 } { ptr @fld.str.452, i64 13 }, { ptr, i64 } { ptr @fld.str.453, i64 17 }] -@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.456 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.460 = private constant [10 x i8] c"allocator\00" -@fld.str.461 = private constant [5 x i8] c"data\00" -@field_names.462 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 9 }, { ptr, i64 } { ptr @fld.str.461, i64 4 }] -@str.463 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.464 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.465 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.466 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.467 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.468 = private constant [3 x i8] c"fd\00" -@field_names.469 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.468, i64 2 }] -@str.470 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.471 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.472 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.474 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.475 = private constant [5 x i8] c"file\00" -@fld.str.476 = private constant [5 x i8] c"line\00" -@fld.str.477 = private constant [4 x i8] c"col\00" -@fld.str.478 = private constant [5 x i8] c"func\00" -@fld.str.479 = private constant [10 x i8] c"line_text\00" -@field_names.480 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.475, i64 4 }, { ptr, i64 } { ptr @fld.str.476, i64 4 }, { ptr, i64 } { ptr @fld.str.477, i64 3 }, { ptr, i64 } { ptr @fld.str.478, i64 4 }, { ptr, i64 } { ptr @fld.str.479, i64 9 }] -@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.482 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.486 = private constant [10 x i8] c"exit_code\00" -@fld.str.487 = private constant [7 x i8] c"stdout\00" -@field_names.488 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 9 }, { ptr, i64 } { ptr @fld.str.487, i64 6 }] -@str.489 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.490 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.491 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.493 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.494 = private constant [8 x i8] c"sin_len\00" -@fld.str.495 = private constant [11 x i8] c"sin_family\00" -@fld.str.496 = private constant [9 x i8] c"sin_port\00" -@fld.str.497 = private constant [9 x i8] c"sin_addr\00" -@fld.str.498 = private constant [9 x i8] c"sin_zero\00" -@field_names.499 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.494, i64 7 }, { ptr, i64 } { ptr @fld.str.495, i64 10 }, { ptr, i64 } { ptr @fld.str.496, i64 8 }, { ptr, i64 } { ptr @fld.str.497, i64 8 }, { ptr, i64 } { ptr @fld.str.498, i64 8 }] -@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.501 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.502 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.503 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.504 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.505 = private constant [6 x i8] c"items\00" -@fld.str.506 = private constant [4 x i8] c"len\00" -@fld.str.507 = private constant [4 x i8] c"cap\00" -@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 5 }, { ptr, i64 } { ptr @fld.str.506, i64 3 }, { ptr, i64 } { ptr @fld.str.507, i64 3 }] -@str.509 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.510 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.511 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.512 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.513 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.514 = private constant [6 x i8] c"items\00" -@fld.str.515 = private constant [4 x i8] c"len\00" -@fld.str.516 = private constant [4 x i8] c"cap\00" -@field_names.517 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.514, i64 5 }, { ptr, i64 } { ptr @fld.str.515, i64 3 }, { ptr, i64 } { ptr @fld.str.516, i64 3 }] -@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.519 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.523 = private constant [4 x i8] c"key\00" -@fld.str.524 = private constant [4 x i8] c"val\00" -@field_names.525 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 3 }, { ptr, i64 } { ptr @fld.str.524, i64 3 }] -@str.526 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.527 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.528 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.529 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.530 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.531 = private constant [4 x i8] c"dst\00" -@fld.str.532 = private constant [4 x i8] c"pos\00" -@fld.str.533 = private constant [5 x i8] c"file\00" -@field_names.534 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.531, i64 3 }, { ptr, i64 } { ptr @fld.str.532, i64 3 }, { ptr, i64 } { ptr @fld.str.533, i64 4 }] -@str.535 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.536 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.537 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.538 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.539 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.540 = private constant [4 x i8] c"src\00" -@fld.str.541 = private constant [4 x i8] c"pos\00" -@fld.str.542 = private constant [6 x i8] c"alloc\00" -@field_names.543 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.540, i64 3 }, { ptr, i64 } { ptr @fld.str.541, i64 3 }, { ptr, i64 } { ptr @fld.str.542, i64 5 }] -@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.545 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.546 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.547 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.548 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.549 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.551 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.553 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.554 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.555 = private constant [5 x i8] c"name\00" -@fld.str.556 = private constant [12 x i8] c"takes_value\00" -@fld.str.557 = private constant [9 x i8] c"required\00" -@field_names.558 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.555, i64 4 }, { ptr, i64 } { ptr @fld.str.556, i64 11 }, { ptr, i64 } { ptr @fld.str.557, i64 8 }] -@str.559 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.560 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.562 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.563 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.564 = private constant [6 x i8] c"group\00" -@fld.str.565 = private constant [8 x i8] c"command\00" -@fld.str.566 = private constant [6 x i8] c"flags\00" -@field_names.567 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.564, i64 5 }, { ptr, i64 } { ptr @fld.str.565, i64 7 }, { ptr, i64 } { ptr @fld.str.566, i64 5 }] -@str.568 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.569 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.570 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.571 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.572 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.573 = private constant [4 x i8] c"set\00" -@fld.str.574 = private constant [6 x i8] c"value\00" -@field_names.575 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 3 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }] -@str.576 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.577 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.578 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.579 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.580 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.581 = private constant [6 x i8] c"index\00" -@fld.str.582 = private constant [6 x i8] c"token\00" -@field_names.583 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 5 }] -@str.584 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.585 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.586 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.587 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.588 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.589 = private constant [6 x i8] c"group\00" -@fld.str.590 = private constant [8 x i8] c"command\00" -@fld.str.591 = private constant [10 x i8] c"cmd_index\00" -@fld.str.592 = private constant [5 x i8] c"json\00" -@fld.str.593 = private constant [5 x i8] c"rest\00" -@fld.str.594 = private constant [5 x i8] c"spec\00" -@fld.str.595 = private constant [7 x i8] c"values\00" -@field_names.596 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 5 }, { ptr, i64 } { ptr @fld.str.590, i64 7 }, { ptr, i64 } { ptr @fld.str.591, i64 9 }, { ptr, i64 } { ptr @fld.str.592, i64 4 }, { ptr, i64 } { ptr @fld.str.593, i64 4 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }] -@str.597 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.598 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.602 = private constant [2 x i8] c"h\00" -@fld.str.603 = private constant [4 x i8] c"buf\00" -@fld.str.604 = private constant [8 x i8] c"buf_len\00" -@fld.str.605 = private constant [10 x i8] c"total_len\00" -@field_names.606 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 1 }, { ptr, i64 } { ptr @fld.str.603, i64 3 }, { ptr, i64 } { ptr @fld.str.604, i64 7 }, { ptr, i64 } { ptr @fld.str.605, i64 9 }] -@str.607 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.608 = private unnamed_addr constant [9 x i8] c"NSString\00", align 1 -@str.609 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.610 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.611 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.612 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.613 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.614 = private unnamed_addr constant [6 x i8] c"SxBox\00", align 1 -@str.615 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.616 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.617 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.618 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.619 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.620 = private unnamed_addr constant [13 x i8] c"__SxBoxState\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.622 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.623 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.624 = private constant [15 x i8] c"__sx_allocator\00" -@fld.str.625 = private constant [6 x i8] c"width\00" -@fld.str.626 = private constant [7 x i8] c"height\00" -@fld.str.627 = private constant [5 x i8] c"area\00" -@field_names.628 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.624, i64 14 }, { ptr, i64 } { ptr @fld.str.625, i64 5 }, { ptr, i64 } { ptr @fld.str.626, i64 6 }, { ptr, i64 } { ptr @fld.str.627, i64 4 }] -@str.629 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.630 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.631 = private constant [5 x i8] c"read\00" -@fld.str.632 = private constant [6 x i8] c"write\00" -@fld.str.633 = private constant [7 x i8] c"append\00" -@fld.str.634 = private constant [11 x i8] c"read_write\00" -@field_names.635 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.631, i64 4 }, { ptr, i64 } { ptr @fld.str.632, i64 5 }, { ptr, i64 } { ptr @fld.str.633, i64 6 }, { ptr, i64 } { ptr @fld.str.634, i64 10 }] -@str.636 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.638 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.639 = private constant [4 x i8] c"set\00" -@fld.str.640 = private constant [8 x i8] c"current\00" -@fld.str.641 = private constant [4 x i8] c"end\00" -@field_names.642 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.639, i64 3 }, { ptr, i64 } { ptr @fld.str.640, i64 7 }, { ptr, i64 } { ptr @fld.str.641, i64 3 }] -@str.643 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.644 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.645 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.646 = private constant [6 x i8] c"null_\00" -@fld.str.647 = private constant [6 x i8] c"bool_\00" -@fld.str.648 = private constant [5 x i8] c"int_\00" -@fld.str.649 = private constant [4 x i8] c"str\00" -@fld.str.650 = private constant [6 x i8] c"array\00" -@fld.str.651 = private constant [7 x i8] c"object\00" -@field_names.652 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.646, i64 5 }, { ptr, i64 } { ptr @fld.str.647, i64 5 }, { ptr, i64 } { ptr @fld.str.648, i64 4 }, { ptr, i64 } { ptr @fld.str.649, i64 3 }, { ptr, i64 } { ptr @fld.str.650, i64 5 }, { ptr, i64 } { ptr @fld.str.651, i64 6 }] -@str.653 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.654 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.655 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.656 = private constant [6 x i8] c"macos\00" -@fld.str.657 = private constant [6 x i8] c"linux\00" -@fld.str.658 = private constant [8 x i8] c"windows\00" -@fld.str.659 = private constant [5 x i8] c"wasm\00" -@fld.str.660 = private constant [4 x i8] c"ios\00" -@fld.str.661 = private constant [8 x i8] c"android\00" -@fld.str.662 = private constant [8 x i8] c"unknown\00" -@field_names.663 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.656, i64 5 }, { ptr, i64 } { ptr @fld.str.657, i64 5 }, { ptr, i64 } { ptr @fld.str.658, i64 7 }, { ptr, i64 } { ptr @fld.str.659, i64 4 }, { ptr, i64 } { ptr @fld.str.660, i64 3 }, { ptr, i64 } { ptr @fld.str.661, i64 7 }, { ptr, i64 } { ptr @fld.str.662, i64 7 }] -@str.664 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.665 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.666 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.667 = private constant [8 x i8] c"aarch64\00" -@fld.str.668 = private constant [7 x i8] c"x86_64\00" -@fld.str.669 = private constant [7 x i8] c"wasm32\00" -@fld.str.670 = private constant [7 x i8] c"wasm64\00" -@fld.str.671 = private constant [8 x i8] c"unknown\00" -@field_names.672 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.667, i64 7 }, { ptr, i64 } { ptr @fld.str.668, i64 6 }, { ptr, i64 } { ptr @fld.str.669, i64 6 }, { ptr, i64 } { ptr @fld.str.670, i64 6 }, { ptr, i64 } { ptr @fld.str.671, i64 7 }] -@str.673 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.674 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.675 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.676 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.677 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.678 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.679 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.680 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.681 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.682 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.683 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.684 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.685 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.686 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.687 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.688 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.690 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.691 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.693 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.694 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.695 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.696 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.697 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.698 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.699 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.700 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.701 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.702 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.703 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.704 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.705 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.706 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.707 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.708 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.709 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.710 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.712 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.715 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.721 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.724 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.727 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.730 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.733 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.736 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.737 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.739 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.740 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.742 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.743 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.745 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.746 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.748 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.749 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.750 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.751 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.752 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.753 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.754 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.755 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.756 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.757 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.758 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.759 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.760 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.761 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.762 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.763 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.764 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.765 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.766 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.767 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.768 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.769 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.770 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.771 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.772 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.773 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.774 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.775 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.776 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.777 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.778 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.779 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.780 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.781 = private unnamed_addr constant [10 x i8] c"*NSString\00", align 1 -@str.782 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.783 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.784 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.785 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.787 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.788 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.790 = private unnamed_addr constant [7 x i8] c"*SxBox\00", align 1 -@str.791 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.792 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.793 = private unnamed_addr constant [8 x i8] c"**SxBox\00", align 1 -@str.794 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.795 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.796 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.797 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.798 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.799 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.800 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.801 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.802 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.803 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.804 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.805 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.806 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.807 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.808 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.809 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.810 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.811 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 -@str.812 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.813 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.814 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.396 = private constant [5 x i8] c"line\00" +@fld.str.397 = private constant [4 x i8] c"col\00" +@fld.str.398 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.396, i64 4 }, { ptr, i64 } { ptr @fld.str.397, i64 3 }, { ptr, i64 } { ptr @fld.str.398, i64 4 }] +@str.399 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.400 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.401 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.402 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.403 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.404 = private constant [4 x i8] c"ctx\00" +@fld.str.405 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.406 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.407 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.404, i64 3 }, { ptr, i64 } { ptr @fld.str.405, i64 11 }, { ptr, i64 } { ptr @fld.str.406, i64 13 }] +@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.409 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.413 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.414 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.415 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.416 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.417 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.418 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.419 = private constant [12 x i8] c"alloc_count\00" +@field_names.420 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.419, i64 11 }] +@str.421 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.422 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.423 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.424 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.425 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.426 = private constant [5 x i8] c"next\00" +@fld.str.427 = private constant [4 x i8] c"cap\00" +@field_names.428 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.426, i64 4 }, { ptr, i64 } { ptr @fld.str.427, i64 3 }] +@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.430 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.432 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.433 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.434 = private constant [6 x i8] c"first\00" +@fld.str.435 = private constant [10 x i8] c"end_index\00" +@fld.str.436 = private constant [7 x i8] c"parent\00" +@field_names.437 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 5 }, { ptr, i64 } { ptr @fld.str.435, i64 9 }, { ptr, i64 } { ptr @fld.str.436, i64 6 }] +@str.438 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.439 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.441 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.442 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.443 = private constant [4 x i8] c"buf\00" +@fld.str.444 = private constant [4 x i8] c"len\00" +@fld.str.445 = private constant [4 x i8] c"pos\00" +@field_names.446 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.443, i64 3 }, { ptr, i64 } { ptr @fld.str.444, i64 3 }, { ptr, i64 } { ptr @fld.str.445, i64 3 }] +@str.447 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.448 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.449 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.451 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.452 = private constant [7 x i8] c"parent\00" +@fld.str.453 = private constant [12 x i8] c"alloc_count\00" +@fld.str.454 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.455 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.456 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.452, i64 6 }, { ptr, i64 } { ptr @fld.str.453, i64 11 }, { ptr, i64 } { ptr @fld.str.454, i64 13 }, { ptr, i64 } { ptr @fld.str.455, i64 17 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.459 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.460 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.461 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.462 = private constant [10 x i8] c"allocator\00" +@fld.str.463 = private constant [5 x i8] c"data\00" +@field_names.464 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 9 }, { ptr, i64 } { ptr @fld.str.463, i64 4 }] +@str.465 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.466 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.467 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.468 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.469 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.470 = private constant [3 x i8] c"fd\00" +@field_names.471 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.470, i64 2 }] +@str.472 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.473 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.474 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.476 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.477 = private constant [5 x i8] c"file\00" +@fld.str.478 = private constant [5 x i8] c"line\00" +@fld.str.479 = private constant [4 x i8] c"col\00" +@fld.str.480 = private constant [5 x i8] c"func\00" +@fld.str.481 = private constant [10 x i8] c"line_text\00" +@field_names.482 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.477, i64 4 }, { ptr, i64 } { ptr @fld.str.478, i64 4 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 4 }, { ptr, i64 } { ptr @fld.str.481, i64 9 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.485 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.486 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.487 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.488 = private constant [10 x i8] c"exit_code\00" +@fld.str.489 = private constant [7 x i8] c"stdout\00" +@field_names.490 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 9 }, { ptr, i64 } { ptr @fld.str.489, i64 6 }] +@str.491 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.492 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.493 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.495 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.496 = private constant [8 x i8] c"sin_len\00" +@fld.str.497 = private constant [11 x i8] c"sin_family\00" +@fld.str.498 = private constant [9 x i8] c"sin_port\00" +@fld.str.499 = private constant [9 x i8] c"sin_addr\00" +@fld.str.500 = private constant [9 x i8] c"sin_zero\00" +@field_names.501 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.496, i64 7 }, { ptr, i64 } { ptr @fld.str.497, i64 10 }, { ptr, i64 } { ptr @fld.str.498, i64 8 }, { ptr, i64 } { ptr @fld.str.499, i64 8 }, { ptr, i64 } { ptr @fld.str.500, i64 8 }] +@str.502 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.503 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.504 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.505 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.506 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.507 = private constant [6 x i8] c"items\00" +@fld.str.508 = private constant [4 x i8] c"len\00" +@fld.str.509 = private constant [4 x i8] c"cap\00" +@field_names.510 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.507, i64 5 }, { ptr, i64 } { ptr @fld.str.508, i64 3 }, { ptr, i64 } { ptr @fld.str.509, i64 3 }] +@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.512 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.513 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.514 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.515 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.516 = private constant [6 x i8] c"items\00" +@fld.str.517 = private constant [4 x i8] c"len\00" +@fld.str.518 = private constant [4 x i8] c"cap\00" +@field_names.519 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 5 }, { ptr, i64 } { ptr @fld.str.517, i64 3 }, { ptr, i64 } { ptr @fld.str.518, i64 3 }] +@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.521 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.522 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.523 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.524 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.525 = private constant [4 x i8] c"key\00" +@fld.str.526 = private constant [4 x i8] c"val\00" +@field_names.527 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 3 }, { ptr, i64 } { ptr @fld.str.526, i64 3 }] +@str.528 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.529 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.530 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.531 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.532 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.533 = private constant [4 x i8] c"dst\00" +@fld.str.534 = private constant [4 x i8] c"pos\00" +@fld.str.535 = private constant [5 x i8] c"file\00" +@field_names.536 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.533, i64 3 }, { ptr, i64 } { ptr @fld.str.534, i64 3 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }] +@str.537 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.538 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.539 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.540 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.541 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.542 = private constant [4 x i8] c"src\00" +@fld.str.543 = private constant [4 x i8] c"pos\00" +@fld.str.544 = private constant [6 x i8] c"alloc\00" +@field_names.545 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.542, i64 3 }, { ptr, i64 } { ptr @fld.str.543, i64 3 }, { ptr, i64 } { ptr @fld.str.544, i64 5 }] +@str.546 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.547 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.548 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.549 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.550 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.551 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.552 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.553 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.555 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.556 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.557 = private constant [5 x i8] c"name\00" +@fld.str.558 = private constant [12 x i8] c"takes_value\00" +@fld.str.559 = private constant [9 x i8] c"required\00" +@field_names.560 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 11 }, { ptr, i64 } { ptr @fld.str.559, i64 8 }] +@str.561 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.562 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.564 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.565 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.566 = private constant [6 x i8] c"group\00" +@fld.str.567 = private constant [8 x i8] c"command\00" +@fld.str.568 = private constant [6 x i8] c"flags\00" +@field_names.569 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 5 }, { ptr, i64 } { ptr @fld.str.567, i64 7 }, { ptr, i64 } { ptr @fld.str.568, i64 5 }] +@str.570 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.571 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.572 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.573 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.574 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.575 = private constant [4 x i8] c"set\00" +@fld.str.576 = private constant [6 x i8] c"value\00" +@field_names.577 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 3 }, { ptr, i64 } { ptr @fld.str.576, i64 5 }] +@str.578 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.579 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.581 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.582 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.583 = private constant [6 x i8] c"index\00" +@fld.str.584 = private constant [6 x i8] c"token\00" +@field_names.585 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 5 }] +@str.586 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.587 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.588 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.589 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.590 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.591 = private constant [6 x i8] c"group\00" +@fld.str.592 = private constant [8 x i8] c"command\00" +@fld.str.593 = private constant [10 x i8] c"cmd_index\00" +@fld.str.594 = private constant [5 x i8] c"json\00" +@fld.str.595 = private constant [5 x i8] c"rest\00" +@fld.str.596 = private constant [5 x i8] c"spec\00" +@fld.str.597 = private constant [7 x i8] c"values\00" +@field_names.598 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.591, i64 5 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }, { ptr, i64 } { ptr @fld.str.593, i64 9 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 4 }, { ptr, i64 } { ptr @fld.str.596, i64 4 }, { ptr, i64 } { ptr @fld.str.597, i64 6 }] +@str.599 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.600 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.604 = private constant [2 x i8] c"h\00" +@fld.str.605 = private constant [4 x i8] c"buf\00" +@fld.str.606 = private constant [8 x i8] c"buf_len\00" +@fld.str.607 = private constant [10 x i8] c"total_len\00" +@field_names.608 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.604, i64 1 }, { ptr, i64 } { ptr @fld.str.605, i64 3 }, { ptr, i64 } { ptr @fld.str.606, i64 7 }, { ptr, i64 } { ptr @fld.str.607, i64 9 }] +@str.609 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.610 = private unnamed_addr constant [9 x i8] c"NSString\00", align 1 +@str.611 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.612 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.613 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.614 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.615 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.616 = private unnamed_addr constant [6 x i8] c"SxBox\00", align 1 +@str.617 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.618 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.619 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.620 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.621 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.622 = private unnamed_addr constant [13 x i8] c"__SxBoxState\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.624 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.625 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.626 = private constant [15 x i8] c"__sx_allocator\00" +@fld.str.627 = private constant [6 x i8] c"width\00" +@fld.str.628 = private constant [7 x i8] c"height\00" +@fld.str.629 = private constant [5 x i8] c"area\00" +@field_names.630 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.626, i64 14 }, { ptr, i64 } { ptr @fld.str.627, i64 5 }, { ptr, i64 } { ptr @fld.str.628, i64 6 }, { ptr, i64 } { ptr @fld.str.629, i64 4 }] +@str.631 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.632 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.633 = private constant [5 x i8] c"read\00" +@fld.str.634 = private constant [6 x i8] c"write\00" +@fld.str.635 = private constant [7 x i8] c"append\00" +@fld.str.636 = private constant [11 x i8] c"read_write\00" +@field_names.637 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.633, i64 4 }, { ptr, i64 } { ptr @fld.str.634, i64 5 }, { ptr, i64 } { ptr @fld.str.635, i64 6 }, { ptr, i64 } { ptr @fld.str.636, i64 10 }] +@str.638 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.640 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.641 = private constant [4 x i8] c"set\00" +@fld.str.642 = private constant [8 x i8] c"current\00" +@fld.str.643 = private constant [4 x i8] c"end\00" +@field_names.644 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.641, i64 3 }, { ptr, i64 } { ptr @fld.str.642, i64 7 }, { ptr, i64 } { ptr @fld.str.643, i64 3 }] +@str.645 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.646 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.647 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.648 = private constant [6 x i8] c"null_\00" +@fld.str.649 = private constant [6 x i8] c"bool_\00" +@fld.str.650 = private constant [5 x i8] c"int_\00" +@fld.str.651 = private constant [4 x i8] c"str\00" +@fld.str.652 = private constant [6 x i8] c"array\00" +@fld.str.653 = private constant [7 x i8] c"object\00" +@field_names.654 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.648, i64 5 }, { ptr, i64 } { ptr @fld.str.649, i64 5 }, { ptr, i64 } { ptr @fld.str.650, i64 4 }, { ptr, i64 } { ptr @fld.str.651, i64 3 }, { ptr, i64 } { ptr @fld.str.652, i64 5 }, { ptr, i64 } { ptr @fld.str.653, i64 6 }] +@str.655 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.656 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.657 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.658 = private constant [6 x i8] c"macos\00" +@fld.str.659 = private constant [6 x i8] c"linux\00" +@fld.str.660 = private constant [8 x i8] c"windows\00" +@fld.str.661 = private constant [5 x i8] c"wasm\00" +@fld.str.662 = private constant [4 x i8] c"ios\00" +@fld.str.663 = private constant [8 x i8] c"android\00" +@fld.str.664 = private constant [8 x i8] c"unknown\00" +@field_names.665 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.658, i64 5 }, { ptr, i64 } { ptr @fld.str.659, i64 5 }, { ptr, i64 } { ptr @fld.str.660, i64 7 }, { ptr, i64 } { ptr @fld.str.661, i64 4 }, { ptr, i64 } { ptr @fld.str.662, i64 3 }, { ptr, i64 } { ptr @fld.str.663, i64 7 }, { ptr, i64 } { ptr @fld.str.664, i64 7 }] +@str.666 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.667 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.668 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.669 = private constant [8 x i8] c"aarch64\00" +@fld.str.670 = private constant [7 x i8] c"x86_64\00" +@fld.str.671 = private constant [7 x i8] c"wasm32\00" +@fld.str.672 = private constant [7 x i8] c"wasm64\00" +@fld.str.673 = private constant [8 x i8] c"unknown\00" +@field_names.674 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.669, i64 7 }, { ptr, i64 } { ptr @fld.str.670, i64 6 }, { ptr, i64 } { ptr @fld.str.671, i64 6 }, { ptr, i64 } { ptr @fld.str.672, i64 6 }, { ptr, i64 } { ptr @fld.str.673, i64 7 }] +@str.675 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.676 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.677 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.678 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.679 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.680 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.681 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.682 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.683 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.684 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.685 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.686 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.687 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.688 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.689 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.690 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.691 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.692 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.693 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.694 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.695 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.696 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.697 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.698 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.699 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.700 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.701 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.702 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.703 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.704 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.705 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.706 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.707 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.708 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.709 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.710 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.711 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.712 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.713 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.714 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.715 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.716 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.717 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.718 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.719 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.722 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.723 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.725 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.726 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.727 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.728 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.729 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.730 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.731 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.732 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.733 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.734 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.735 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.736 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.737 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.738 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.739 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.740 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.741 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.742 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.743 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.744 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.745 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.747 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.748 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.749 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.750 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.751 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.752 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.753 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.754 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.755 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.756 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.757 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.758 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.759 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.760 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.761 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.762 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.763 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.765 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.766 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.767 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.768 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.769 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.770 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.771 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.772 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.773 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.774 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.775 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.776 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.777 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.778 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.779 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.780 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.781 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.782 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.783 = private unnamed_addr constant [10 x i8] c"*NSString\00", align 1 +@str.784 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.785 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.786 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.787 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.788 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.789 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.790 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.791 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.792 = private unnamed_addr constant [7 x i8] c"*SxBox\00", align 1 +@str.793 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.795 = private unnamed_addr constant [8 x i8] c"**SxBox\00", align 1 +@str.796 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.798 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.799 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.800 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.801 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.802 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.803 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.804 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.805 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.806 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.807 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.808 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.809 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.810 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.811 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.812 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.813 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.814 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.815 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.816 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.817 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.818 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [5 x i8] c"init\00" -@OBJC_METH_VAR_NAME_.817 = private unnamed_addr constant [10 x i8] c"setWidth:\00" -@OBJC_METH_VAR_NAME_.818 = private unnamed_addr constant [11 x i8] c"setHeight:\00" -@OBJC_METH_VAR_NAME_.819 = private unnamed_addr constant [6 x i8] c"width\00" -@OBJC_METH_VAR_NAME_.820 = private unnamed_addr constant [7 x i8] c"height\00" -@OBJC_METH_VAR_NAME_.821 = private unnamed_addr constant [5 x i8] c"area\00" +@OBJC_METH_VAR_NAME_.819 = private unnamed_addr constant [10 x i8] c"setWidth:\00" +@OBJC_METH_VAR_NAME_.820 = private unnamed_addr constant [11 x i8] c"setHeight:\00" +@OBJC_METH_VAR_NAME_.821 = private unnamed_addr constant [6 x i8] c"width\00" +@OBJC_METH_VAR_NAME_.822 = private unnamed_addr constant [7 x i8] c"height\00" +@OBJC_METH_VAR_NAME_.823 = private unnamed_addr constant [5 x i8] c"area\00" @OBJC_IVAR_NAME_ = private unnamed_addr constant [11 x i8] c"__sx_state\00" @OBJC_IVAR_TYPE_ = private unnamed_addr constant [3 x i8] c"^v\00" @OBJC_CLASS_NAME_ = private unnamed_addr constant [9 x i8] c"NSObject\00" -@OBJC_CLASS_NAME_.822 = private unnamed_addr constant [6 x i8] c"SxBox\00" -@OBJC_METH_VAR_NAME_.823 = private unnamed_addr constant [6 x i8] c"width\00" +@OBJC_CLASS_NAME_.824 = private unnamed_addr constant [6 x i8] c"SxBox\00" +@OBJC_METH_VAR_NAME_.825 = private unnamed_addr constant [6 x i8] c"width\00" @OBJC_METH_VAR_TYPE_ = private unnamed_addr constant [4 x i8] c"i@:\00" -@OBJC_METH_VAR_NAME_.824 = private unnamed_addr constant [10 x i8] c"setWidth:\00" -@OBJC_METH_VAR_TYPE_.825 = private unnamed_addr constant [5 x i8] c"v@:i\00" -@OBJC_METH_VAR_NAME_.826 = private unnamed_addr constant [7 x i8] c"height\00" -@OBJC_METH_VAR_TYPE_.827 = private unnamed_addr constant [4 x i8] c"i@:\00" -@OBJC_METH_VAR_NAME_.828 = private unnamed_addr constant [11 x i8] c"setHeight:\00" -@OBJC_METH_VAR_TYPE_.829 = private unnamed_addr constant [5 x i8] c"v@:i\00" -@OBJC_METH_VAR_NAME_.830 = private unnamed_addr constant [5 x i8] c"area\00" -@OBJC_METH_VAR_TYPE_.831 = private unnamed_addr constant [4 x i8] c"i@:\00" -@OBJC_METH_VAR_NAME_.832 = private unnamed_addr constant [8 x i8] c"dealloc\00" -@OBJC_METH_VAR_TYPE_.833 = private unnamed_addr constant [4 x i8] c"v@:\00" -@OBJC_METH_VAR_NAME_.834 = private unnamed_addr constant [6 x i8] c"alloc\00" -@OBJC_METH_VAR_TYPE_.835 = private unnamed_addr constant [4 x i8] c"@@:\00" -@OBJC_CLASS_NAME_.836 = private unnamed_addr constant [6 x i8] c"SxBox\00" +@OBJC_METH_VAR_NAME_.826 = private unnamed_addr constant [10 x i8] c"setWidth:\00" +@OBJC_METH_VAR_TYPE_.827 = private unnamed_addr constant [5 x i8] c"v@:i\00" +@OBJC_METH_VAR_NAME_.828 = private unnamed_addr constant [7 x i8] c"height\00" +@OBJC_METH_VAR_TYPE_.829 = private unnamed_addr constant [4 x i8] c"i@:\00" +@OBJC_METH_VAR_NAME_.830 = private unnamed_addr constant [11 x i8] c"setHeight:\00" +@OBJC_METH_VAR_TYPE_.831 = private unnamed_addr constant [5 x i8] c"v@:i\00" +@OBJC_METH_VAR_NAME_.832 = private unnamed_addr constant [5 x i8] c"area\00" +@OBJC_METH_VAR_TYPE_.833 = private unnamed_addr constant [4 x i8] c"i@:\00" +@OBJC_METH_VAR_NAME_.834 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.835 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.836 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.837 = private unnamed_addr constant [4 x i8] c"@@:\00" +@OBJC_CLASS_NAME_.838 = private unnamed_addr constant [6 x i8] c"SxBox\00" @llvm.global_ctors = appending global [2 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr @__sx_objc_selector_init, ptr null }, { i32, ptr, ptr } { i32 65535, ptr @__sx_objc_class_init, ptr null }] ; Function Attrs: nounwind @@ -711,6 +711,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -930,7 +933,7 @@ entry: br i1 %icmp, label %if.then.64, label %if.merge.65 if.then.64: ; preds = %entry - ret { ptr, i64 } { ptr @str.162, i64 1 } + ret { ptr, i64 } { ptr @str.164, i64 1 } if.merge.65: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1057,7 +1060,7 @@ if.else.87: ; preds = %entry br label %if.merge.88 if.merge.88: ; preds = %if.else.87, %if.then.86 - %bp = phi { ptr, i64 } [ { ptr @str.163, i64 4 }, %if.then.86 ], [ { ptr @str.164, i64 5 }, %if.else.87 ] + %bp = phi { ptr, i64 } [ { ptr @str.165, i64 4 }, %if.then.86 ], [ { ptr @str.166, i64 5 }, %if.else.87 ] ret { ptr, i64 } %bp } @@ -1391,7 +1394,7 @@ entry: br i1 %icmp, label %if.then.404, label %if.merge.405 if.then.404: ; preds = %entry - ret { ptr, i64 } { ptr @str.165, i64 1 } + ret { ptr, i64 } { ptr @str.167, i64 1 } if.merge.405: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1541,7 +1544,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.166, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.168, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1567,9 +1570,9 @@ entry: i64 11, label %match.arm.50 i64 19, label %match.arm.51 i64 20, label %match.arm.51 - i64 22, label %match.arm.51 - i64 24, label %match.arm.51 - i64 26, label %match.arm.51 + i64 21, label %match.arm.51 + i64 23, label %match.arm.51 + i64 25, label %match.arm.51 i64 27, label %match.arm.51 i64 30, label %match.arm.51 i64 32, label %match.arm.51 @@ -1614,9 +1617,9 @@ entry: i64 85, label %match.arm.56 i64 103, label %match.arm.56 i64 18, label %match.arm.57 - i64 21, label %match.arm.57 - i64 23, label %match.arm.57 - i64 25, label %match.arm.57 + i64 22, label %match.arm.57 + i64 24, label %match.arm.57 + i64 26, label %match.arm.57 i64 28, label %match.arm.57 i64 29, label %match.arm.57 i64 31, label %match.arm.57 @@ -1659,7 +1662,7 @@ match.merge.45: ; preds = %dispatch.merge.516, ret { ptr, i64 } %loadN match.arm.46: ; preds = %entry - store { ptr, i64 } { ptr @str.167, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.169, i64 0 }, ptr %allocaN, align 8 br label %match.merge.45 match.arm.47: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1703,9 +1706,9 @@ match.arm.51: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.103 [ i64 19, label %dispatch.case.104 i64 20, label %dispatch.case.105 - i64 22, label %dispatch.case.106 - i64 24, label %dispatch.case.107 - i64 26, label %dispatch.case.108 + i64 21, label %dispatch.case.106 + i64 23, label %dispatch.case.107 + i64 25, label %dispatch.case.108 i64 27, label %dispatch.case.109 i64 30, label %dispatch.case.110 i64 32, label %dispatch.case.111 @@ -1790,9 +1793,9 @@ match.arm.57: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.366 [ i64 18, label %dispatch.case.367 - i64 21, label %dispatch.case.368 - i64 23, label %dispatch.case.369 - i64 25, label %dispatch.case.370 + i64 22, label %dispatch.case.368 + i64 24, label %dispatch.case.369 + i64 26, label %dispatch.case.370 i64 28, label %dispatch.case.371 i64 29, label %dispatch.case.372 i64 31, label %dispatch.case.373 @@ -1893,7 +1896,7 @@ dispatch.merge.102: ; preds = %dispatch.case.131, br label %match.merge.45 dispatch.default.103: ; preds = %match.arm.51 - store { ptr, i64 } { ptr @str.355, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.357, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.104: ; preds = %match.arm.51 @@ -1907,32 +1910,32 @@ dispatch.case.104: ; preds = %match.arm.51 dispatch.case.105: ; preds = %match.arm.51 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.106: ; preds = %match.arm.51 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.107: ; preds = %match.arm.51 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.108: ; preds = %match.arm.51 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 @@ -2126,7 +2129,7 @@ dispatch.merge.272: ; preds = %dispatch.case.278, br label %match.merge.45 dispatch.default.273: ; preds = %match.arm.52 - store { ptr, i64 } { ptr @str.356, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.358, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.272 dispatch.case.274: ; preds = %match.arm.52 @@ -2167,7 +2170,7 @@ dispatch.merge.289: ; preds = %dispatch.case.297, br label %match.merge.45 dispatch.default.290: ; preds = %match.arm.55 - store { ptr, i64 } { ptr @str.357, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.359, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.289 dispatch.case.291: ; preds = %match.arm.55 @@ -2232,7 +2235,7 @@ dispatch.merge.333: ; preds = %dispatch.case.339, br label %match.merge.45 dispatch.default.334: ; preds = %match.arm.56 - store { ptr, i64 } { ptr @str.358, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.360, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.56 @@ -2281,7 +2284,7 @@ dispatch.merge.365: ; preds = %dispatch.case.400, br label %match.merge.45 dispatch.default.366: ; preds = %match.arm.57 - store { ptr, i64 } { ptr @str.359, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.361, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.365 dispatch.case.367: ; preds = %match.arm.57 @@ -2528,7 +2531,7 @@ dispatch.merge.516: ; preds = %dispatch.case.521, br label %match.merge.45 dispatch.default.517: ; preds = %match.arm.58 - store { ptr, i64 } { ptr @str.360, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.362, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.516 dispatch.case.518: ; preds = %match.arm.58 @@ -2570,7 +2573,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.361, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.363, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2666,7 +2669,7 @@ if.merge.15: ; preds = %if.merge.29, %if.me if.then.16: ; preds = %if.then.13 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2674,7 +2677,7 @@ if.then.16: ; preds = %if.then.13 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2684,13 +2687,13 @@ if.then.16: ; preds = %if.then.13 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.17 if.merge.17: ; preds = %if.then.16, %if.then.13 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2698,7 +2701,7 @@ if.merge.17: ; preds = %if.then.16, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2712,7 +2715,7 @@ if.merge.17: ; preds = %if.then.16, %if.the if.then.27: ; preds = %if.else.14 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2720,7 +2723,7 @@ if.then.27: ; preds = %if.else.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2731,7 +2734,7 @@ if.then.27: ; preds = %if.else.14 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2788,7 +2791,7 @@ if.merge.35: ; preds = %if.merge.38, %if.el if.then.36: ; preds = %if.then.33 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2796,7 +2799,7 @@ if.then.36: ; preds = %if.then.33 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2807,7 +2810,7 @@ if.then.36: ; preds = %if.then.33 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2827,7 +2830,7 @@ if.merge.38: ; preds = %if.else.37, %if.the if.then.39: ; preds = %while.exit.6 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2835,7 +2838,7 @@ if.then.39: ; preds = %while.exit.6 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, 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 @@ -2846,7 +2849,7 @@ if.then.39: ; preds = %while.exit.6 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.375, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.40 @@ -2856,64 +2859,67 @@ if.merge.40: ; preds = %if.then.39, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3089,163 +3095,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3443,64 +3452,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3530,97 +3539,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3659,118 +3668,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -3903,9 +3912,9 @@ if.then.41: ; preds = %if.merge.3 ret i32 1 if.merge.42: ; preds = %if.merge.3 - %callN = call ptr @objc_getClass(ptr @str.376) + %callN = call ptr @objc_getClass(ptr @str.378) store ptr %callN, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.377) + %callN = call ptr @sel_registerName(ptr @str.379) store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -3945,14 +3954,14 @@ entry: define internal void @print__ct_s8b0209b1c8e86f29__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.378, i64 30 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.380, i64 30 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.379, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.381, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 30) @@ -3968,7 +3977,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.380, i64 30 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.382, i64 30 }) ret { ptr, i64 } %call } @@ -3976,7 +3985,7 @@ entry: define internal void @print__ct_s39d1c95f7ad02cfe__pack_s32(ptr %0, i32 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.381, i64 30 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.383, i64 30 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3992,7 +4001,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.382, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.384, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 27) @@ -4020,7 +4029,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.383, i64 30 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.385, i64 30 }) ret { ptr, i64 } %call } @@ -4028,14 +4037,14 @@ entry: define internal void @print__ct_sa76620ef481aaa22__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.384, i64 51 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.386, i64 51 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.385, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.387, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 51) @@ -4051,7 +4060,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_2(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.386, i64 51 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.388, i64 51 }) ret { ptr, i64 } %call } @@ -4059,7 +4068,7 @@ entry: define internal void @print__ct_se44eb1a972327e7d__pack_s32_s32_s32(ptr %0, i32 %1, i32 %2, i32 %3) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.387, i64 28 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.389, i64 28 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca i32, align 4 @@ -4089,7 +4098,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 3, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.388, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.390, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -4141,7 +4150,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_3(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.389, i64 28 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.391, i64 28 }) ret { ptr, i64 } %call } @@ -4152,7 +4161,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 15 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 15 }, { ptr, i64 } { ptr @str.393, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4171,12 +4180,12 @@ while.body.133: ; preds = %while.hdr.132 while.exit.134: ; preds = %while.hdr.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.394, i64 1 }) ret { ptr, i64 } %callN if.then.135: ; preds = %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.395, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.136 @@ -4188,7 +4197,7 @@ if.merge.136: ; preds = %if.then.135, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.399, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4241,20 +4250,20 @@ fv.case24: ; preds = %if.merge.136 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 10 }, { ptr, i64 } { ptr @str.399, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 9 }, { ptr, i64 } { ptr @str.401, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.137 -while.hdr.137: ; preds = %if.merge.141, %entry +while.hdr.137: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.138, label %while.exit.139 while.body.138: ; preds = %while.hdr.137 @@ -4264,224 +4273,24 @@ while.body.138: ; preds = %while.hdr.137 while.exit.139: ; preds = %while.hdr.137 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 1 }) ret { ptr, i64 } %callN if.then.140: ; preds = %while.body.138 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.141 if.merge.141: ; preds = %if.then.140, %while.body.138 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 3 }, { ptr, i64 } { ptr @str.405, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 - -while.hdr.142: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.143, label %while.exit.144 - -while.body.143: ; preds = %while.hdr.142 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 - -while.exit.144: ; preds = %while.hdr.142 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.406, i64 1 }) - ret { ptr, i64 } %callN - -if.then.145: ; preds = %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 - -if.merge.146: ; preds = %if.then.145, %while.body.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.410, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 - -fv.default: ; preds = %if.merge.146 - br label %fv.merge - -fv.case: ; preds = %if.merge.146 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 10 }, { ptr, i64 } { ptr @str.412, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 - -while.hdr.147: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.148, label %while.exit.149 - -while.body.148: ; preds = %while.hdr.147 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 - -while.exit.149: ; preds = %while.hdr.147 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.413, i64 1 }) - ret { ptr, i64 } %callN - -if.then.150: ; preds = %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 - -if.merge.151: ; preds = %if.then.150, %while.body.148 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.417, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.147 - -fv.default: ; preds = %if.merge.151 - br label %fv.merge - -fv.case: ; preds = %if.merge.151 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.151 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 9 }, { ptr, i64 } { ptr @str.420, i64 1 }) - %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %call, ptr %allocaN, align 8 - %allocaN = alloca i64, align 8 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.152 - -while.hdr.152: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.153, label %while.exit.154 - -while.body.153: ; preds = %while.hdr.152 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.155, label %if.merge.156 - -while.exit.154: ; preds = %while.hdr.152 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 1 }) - ret { ptr, i64 } %callN - -if.then.155: ; preds = %while.body.153 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.156 - -if.merge.156: ; preds = %if.then.155, %while.body.153 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.426, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.427, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, 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 @@ -4500,27 +4309,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 + +fv.default: ; preds = %if.merge.141 + br label %fv.merge + +fv.case: ; preds = %if.merge.141 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.141 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.141 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 10 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.142 + +while.hdr.142: ; preds = %if.merge.146, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.143, label %while.exit.144 + +while.body.143: ; preds = %while.hdr.142 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.145, label %if.merge.146 + +while.exit.144: ; preds = %while.hdr.142 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) + ret { ptr, i64 } %callN + +if.then.145: ; preds = %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.146 + +if.merge.146: ; preds = %if.then.145, %while.body.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.413, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.142 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.415, i64 3 }, { ptr, i64 } { ptr @str.416, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.147 + +while.hdr.147: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.148, label %while.exit.149 + +while.body.148: ; preds = %while.hdr.147 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.150, label %if.merge.151 + +while.exit.149: ; preds = %while.hdr.147 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 1 }) + ret { ptr, i64 } %callN + +if.then.150: ; preds = %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.151 + +if.merge.151: ; preds = %if.then.150, %while.body.148 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.420, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.147 + +fv.default: ; preds = %if.merge.151 + br label %fv.merge + +fv.case: ; preds = %if.merge.151 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.422, i64 10 }, { ptr, i64 } { ptr @str.423, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.152 + +while.hdr.152: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.153, label %while.exit.154 + +while.body.153: ; preds = %while.hdr.152 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.155, label %if.merge.156 + +while.exit.154: ; preds = %while.hdr.152 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 1 }) + ret { ptr, i64 } %callN + +if.then.155: ; preds = %while.body.153 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.425, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.156 + +if.merge.156: ; preds = %if.then.155, %while.body.153 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.428, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.152 fv.default: ; preds = %if.merge.156 br label %fv.merge fv.case: ; preds = %if.merge.156 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.156 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.156 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4530,7 +4539,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 5 }, { ptr, i64 } { ptr @str.429, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 5 }, { ptr, i64 } { ptr @str.431, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4549,24 +4558,24 @@ while.body.158: ; preds = %while.hdr.157 while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 1 }) ret { ptr, i64 } %callN if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.433, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.161 if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.437, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.436, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, 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 @@ -4593,7 +4602,7 @@ fv.default: ; preds = %if.merge.161 fv.case: ; preds = %if.merge.161 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 @@ -4605,7 +4614,7 @@ fv.case20: ; preds = %if.merge.161 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4614,7 +4623,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 8 }, { ptr, i64 } { ptr @str.438, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 8 }, { ptr, i64 } { ptr @str.440, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4633,24 +4642,24 @@ while.body.163: ; preds = %while.hdr.162 while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 1 }) ret { ptr, i64 } %callN if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.442, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.166 if.merge.166: ; preds = %if.then.165, %while.body.163 %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.444, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.446, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, 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 @@ -4697,7 +4706,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.446, i64 17 }, { ptr, i64 } { ptr @str.447, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.448, i64 17 }, { ptr, i64 } { ptr @str.449, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4716,24 +4725,24 @@ while.body.168: ; preds = %while.hdr.167 while.exit.169: ; preds = %while.hdr.167 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 1 }) ret { ptr, i64 } %callN if.then.170: ; preds = %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.171 if.merge.171: ; preds = %if.then.170, %while.body.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.456, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4762,7 +4771,7 @@ fv.case: ; preds = %if.merge.171 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 @@ -4787,7 +4796,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 7 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 7 }, { ptr, i64 } { ptr @str.459, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4806,24 +4815,24 @@ while.body.173: ; preds = %while.hdr.172 while.exit.174: ; preds = %while.hdr.172 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 1 }) ret { ptr, i64 } %callN if.then.175: ; preds = %while.body.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.176 if.merge.176: ; preds = %if.then.175, %while.body.173 %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.462, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.464, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, 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 @@ -4850,7 +4859,7 @@ fv.case: ; preds = %if.merge.176 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.176 @@ -4865,7 +4874,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.464, i64 4 }, { ptr, i64 } { ptr @str.465, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.466, i64 4 }, { ptr, i64 } { ptr @str.467, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4884,24 +4893,24 @@ while.body.178: ; preds = %while.hdr.177 while.exit.179: ; preds = %while.hdr.177 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.468, i64 1 }) ret { ptr, i64 } %callN if.then.180: ; preds = %while.body.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.467, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.469, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.181 if.merge.181: ; preds = %if.then.180, %while.body.178 %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.469, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.471, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.470, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4938,7 +4947,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 10 }, { ptr, i64 } { ptr @str.472, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.473, i64 10 }, { ptr, i64 } { ptr @str.474, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4957,24 +4966,24 @@ while.body.183: ; preds = %while.hdr.182 while.exit.184: ; preds = %while.hdr.182 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 1 }) ret { ptr, i64 } %callN if.then.185: ; preds = %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.186 if.merge.186: ; preds = %if.then.185, %while.body.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.482, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5040,7 +5049,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 13 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 13 }, { ptr, i64 } { ptr @str.485, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5059,24 +5068,24 @@ while.body.188: ; preds = %while.hdr.187 while.exit.189: ; preds = %while.hdr.187 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.486, i64 1 }) ret { ptr, i64 } %callN if.then.190: ; preds = %while.body.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.191 if.merge.191: ; preds = %if.then.190, %while.body.188 %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.488, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.490, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.489, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.491, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5118,7 +5127,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.490, i64 8 }, { ptr, i64 } { ptr @str.491, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5137,24 +5146,24 @@ while.body.193: ; preds = %while.hdr.192 while.exit.194: ; preds = %while.hdr.192 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 1 }) ret { ptr, i64 } %callN if.then.195: ; preds = %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.196 if.merge.196: ; preds = %if.then.195, %while.body.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.499, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.501, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.500, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5215,7 +5224,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 5 }, { ptr, i64 } { ptr @str.502, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.503, i64 5 }, { ptr, i64 } { ptr @str.504, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5234,24 +5243,24 @@ while.body.198: ; preds = %while.hdr.197 while.exit.199: ; preds = %while.hdr.197 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 1 }) ret { ptr, i64 } %callN if.then.200: ; preds = %while.body.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.201 if.merge.201: ; preds = %if.then.200, %while.body.198 %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.508, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.510, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.509, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, 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 @@ -5297,7 +5306,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 6 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 6 }, { ptr, i64 } { ptr @str.513, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5316,24 +5325,24 @@ while.body.203: ; preds = %while.hdr.202 while.exit.204: ; preds = %while.hdr.202 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 1 }) ret { ptr, i64 } %callN if.then.205: ; preds = %while.body.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.515, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.206 if.merge.206: ; preds = %if.then.205, %while.body.203 %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.517, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.519, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, 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 @@ -5381,7 +5390,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 6 }, { ptr, i64 } { ptr @str.520, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 6 }, { ptr, i64 } { ptr @str.522, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5400,24 +5409,24 @@ while.body.208: ; preds = %while.hdr.207 while.exit.209: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.523, i64 1 }) ret { ptr, i64 } %callN if.then.210: ; preds = %while.body.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.524, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.211 if.merge.211: ; preds = %if.then.210, %while.body.208 %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.525, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.527, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.526, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5461,7 +5470,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.527, i64 4 }, { ptr, i64 } { ptr @str.528, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.529, i64 4 }, { ptr, i64 } { ptr @str.530, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5480,24 +5489,24 @@ while.body.213: ; preds = %while.hdr.212 while.exit.214: ; preds = %while.hdr.212 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 1 }) ret { ptr, i64 } %callN if.then.215: ; preds = %while.body.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.532, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.216 if.merge.216: ; preds = %if.then.215, %while.body.213 %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.534, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.536, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.535, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5547,7 +5556,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.536, i64 6 }, { ptr, i64 } { ptr @str.537, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.538, i64 6 }, { ptr, i64 } { ptr @str.539, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5566,24 +5575,24 @@ while.body.218: ; preds = %while.hdr.217 while.exit.219: ; preds = %while.hdr.217 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 1 }) ret { ptr, i64 } %callN if.then.220: ; preds = %while.body.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.541, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.221 if.merge.221: ; preds = %if.then.220, %while.body.218 %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.543, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.545, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5623,7 +5632,7 @@ fv.case20: ; preds = %if.merge.221 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5632,7 +5641,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 12 }, { ptr, i64 } { ptr @str.546, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.547, i64 12 }, { ptr, i64 } { ptr @str.548, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5651,24 +5660,24 @@ while.body.223: ; preds = %while.hdr.222 while.exit.224: ; preds = %while.hdr.222 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.547, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 1 }) ret { ptr, i64 } %callN if.then.225: ; preds = %while.body.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.548, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.226 if.merge.226: ; preds = %if.then.225, %while.body.223 %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.549, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.551, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.550, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5688,7 +5697,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, i64 8 }, { ptr, i64 } { ptr @str.552, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.553, i64 8 }, { ptr, i64 } { ptr @str.554, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5707,24 +5716,24 @@ while.body.228: ; preds = %while.hdr.227 while.exit.229: ; preds = %while.hdr.227 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 1 }) ret { ptr, i64 } %callN if.then.230: ; preds = %while.body.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.556, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.231 if.merge.231: ; preds = %if.then.230, %while.body.228 %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.558, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.560, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.559, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5776,7 +5785,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, i64 7 }, { ptr, i64 } { ptr @str.561, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 7 }, { ptr, i64 } { ptr @str.563, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5795,24 +5804,24 @@ while.body.233: ; preds = %while.hdr.232 while.exit.234: ; preds = %while.hdr.232 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.564, i64 1 }) ret { ptr, i64 } %callN if.then.235: ; preds = %while.body.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.565, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.236 if.merge.236: ; preds = %if.then.235, %while.body.233 %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.567, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.569, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5864,7 +5873,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 9 }, { ptr, i64 } { ptr @str.570, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 9 }, { ptr, i64 } { ptr @str.572, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5883,24 +5892,24 @@ while.body.238: ; preds = %while.hdr.237 while.exit.239: ; preds = %while.hdr.237 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.573, i64 1 }) ret { ptr, i64 } %callN if.then.240: ; preds = %while.body.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.241 if.merge.241: ; preds = %if.then.240, %while.body.238 %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.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.577, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.576, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5943,7 +5952,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 4 }, { ptr, i64 } { ptr @str.578, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 4 }, { ptr, i64 } { ptr @str.580, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5962,24 +5971,24 @@ while.body.243: ; preds = %while.hdr.242 while.exit.244: ; preds = %while.hdr.242 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.581, i64 1 }) ret { ptr, i64 } %callN if.then.245: ; preds = %while.body.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.246 if.merge.246: ; preds = %if.then.245, %while.body.243 %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.583, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.585, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.584, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.586, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6025,7 +6034,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, i64 6 }, { ptr, i64 } { ptr @str.586, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.587, i64 6 }, { ptr, i64 } { ptr @str.588, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6044,24 +6053,24 @@ while.body.248: ; preds = %while.hdr.247 while.exit.249: ; preds = %while.hdr.247 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 1 }) ret { ptr, i64 } %callN if.then.250: ; preds = %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.251 if.merge.251: ; preds = %if.then.250, %while.body.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -6143,7 +6152,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, i64 6 }, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.600, i64 6 }, { ptr, i64 } { ptr @str.601, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6162,24 +6171,24 @@ while.body.253: ; preds = %while.hdr.252 while.exit.254: ; preds = %while.hdr.252 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %callN if.then.255: ; preds = %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 if.merge.256: ; preds = %if.then.255, %while.body.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.606, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.608, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6234,7 +6243,7 @@ define internal { ptr, i64 } @struct_to_string__NSString(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, i64 8 }, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.610, i64 8 }, { ptr, i64 } { ptr @str.611, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6253,24 +6262,24 @@ while.body.258: ; preds = %while.hdr.257 while.exit.259: ; preds = %while.hdr.257 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.610, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 1 }) ret { ptr, i64 } %callN if.then.260: ; preds = %while.body.258 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.261 if.merge.261: ; preds = %if.then.260, %while.body.258 %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.612, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.614, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.613, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6289,7 +6298,7 @@ define internal { ptr, i64 } @struct_to_string__SxBox(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.614, i64 5 }, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.616, i64 5 }, { ptr, i64 } { ptr @str.617, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6308,24 +6317,24 @@ while.body.263: ; preds = %while.hdr.262 while.exit.264: ; preds = %while.hdr.262 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.616, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.618, i64 1 }) ret { ptr, i64 } %callN if.then.265: ; preds = %while.body.263 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.617, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 if.merge.266: ; preds = %if.then.265, %while.body.263 %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.618, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.620, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.621, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6345,7 +6354,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i32, i32, i32 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i32, i32, i32 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.620, i64 12 }, { ptr, i64 } { ptr @str.621, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.622, i64 12 }, { ptr, i64 } { ptr @str.623, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6364,24 +6373,24 @@ while.body.268: ; preds = %while.hdr.267 while.exit.269: ; preds = %while.hdr.267 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.624, i64 1 }) ret { ptr, i64 } %callN if.then.270: ; preds = %while.body.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.623, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.625, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.271 if.merge.271: ; preds = %if.then.270, %while.body.268 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.628, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.630, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.631, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i32, i32, i32 }, ptr %alloca, align 8 @@ -6410,7 +6419,7 @@ fv.case: ; preds = %if.merge.271 %fv.field = extractvalue { { ptr, ptr, ptr }, i32, i32, i32 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.271 @@ -6441,9 +6450,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.635, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.637, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, 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 @@ -6462,8 +6471,8 @@ entry: if.then.279: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6482,9 +6491,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.642, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.644, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, 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 @@ -6503,8 +6512,8 @@ entry: if.then.281: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.644, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.646, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.282 @@ -6534,9 +6543,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.652, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.654, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.645, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6553,8 +6562,8 @@ entry: if.then.283: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.654, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.656, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.284 @@ -6632,9 +6641,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.663, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.665, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.657, 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 @@ -6653,8 +6662,8 @@ entry: if.then.285: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.286 @@ -6673,9 +6682,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.672, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.674, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.666, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, 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 @@ -6694,8 +6703,8 @@ entry: if.then.287: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.675, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.288 @@ -6712,7 +6721,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.675, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.677, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.298 @@ -6729,12 +6738,12 @@ while.body.299: ; preds = %while.hdr.298 while.exit.300: ; preds = %while.hdr.298 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 1 }) ret { ptr, i64 } %call if.then.301: ; preds = %while.body.299 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.302 @@ -6763,7 +6772,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.678, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.680, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.303 @@ -6780,12 +6789,12 @@ while.body.304: ; preds = %while.hdr.303 while.exit.305: ; preds = %while.hdr.303 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 1 }) ret { ptr, i64 } %call if.then.306: ; preds = %while.body.304 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.307 @@ -6815,7 +6824,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.681, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.683, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.308 @@ -6832,12 +6841,12 @@ while.body.309: ; preds = %while.hdr.308 while.exit.310: ; preds = %while.hdr.308 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 1 }) ret { ptr, i64 } %call if.then.311: ; preds = %while.body.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.312 @@ -6865,7 +6874,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.684, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.686, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.313 @@ -6882,12 +6891,12 @@ while.body.314: ; preds = %while.hdr.313 while.exit.315: ; preds = %while.hdr.313 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 1 }) ret { ptr, i64 } %call if.then.316: ; preds = %while.body.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.317 @@ -6916,7 +6925,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.687, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.689, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.318 @@ -6933,12 +6942,12 @@ while.body.319: ; preds = %while.hdr.318 while.exit.320: ; preds = %while.hdr.318 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 1 }) ret { ptr, i64 } %call if.then.321: ; preds = %while.body.319 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.322 @@ -6967,7 +6976,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.690, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.692, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.323 @@ -6984,12 +6993,12 @@ while.body.324: ; preds = %while.hdr.323 while.exit.325: ; preds = %while.hdr.323 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 1 }) ret { ptr, i64 } %call if.then.326: ; preds = %while.body.324 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.327 @@ -7020,7 +7029,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.693, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.695, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.328 @@ -7037,12 +7046,12 @@ while.body.329: ; preds = %while.hdr.328 while.exit.330: ; preds = %while.hdr.328 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 1 }) ret { ptr, i64 } %call if.then.331: ; preds = %while.body.329 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.332 @@ -7072,7 +7081,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.696, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.698, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.340 @@ -7091,12 +7100,12 @@ while.body.341: ; preds = %while.hdr.340 while.exit.342: ; preds = %while.hdr.340 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.699, i64 1 }) ret { ptr, i64 } %call if.then.343: ; preds = %while.body.341 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.698, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.344 @@ -7125,7 +7134,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.699, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.701, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.345 @@ -7144,12 +7153,12 @@ while.body.346: ; preds = %while.hdr.345 while.exit.347: ; preds = %while.hdr.345 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.702, i64 1 }) ret { ptr, i64 } %call if.then.348: ; preds = %while.body.346 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.701, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.703, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.349 @@ -7178,7 +7187,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.702, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.704, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.350 @@ -7197,12 +7206,12 @@ while.body.351: ; preds = %while.hdr.350 while.exit.352: ; preds = %while.hdr.350 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.703, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.705, i64 1 }) ret { ptr, i64 } %call if.then.353: ; preds = %while.body.351 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.704, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.354 @@ -7232,7 +7241,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.705, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.707, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.355 @@ -7251,12 +7260,12 @@ while.body.356: ; preds = %while.hdr.355 while.exit.357: ; preds = %while.hdr.355 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.706, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.708, i64 1 }) ret { ptr, i64 } %call if.then.358: ; preds = %while.body.356 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.707, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.359 @@ -7286,7 +7295,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.708, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.710, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.360 @@ -7305,12 +7314,12 @@ while.body.361: ; preds = %while.hdr.360 while.exit.362: ; preds = %while.hdr.360 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.711, i64 1 }) ret { ptr, i64 } %call if.then.363: ; preds = %while.body.361 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.710, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.712, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.364 @@ -7352,12 +7361,12 @@ if.then.401: ; preds = %entry if.else.402: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 5 }, { ptr, i64 } %callN) br label %if.merge.403 if.merge.403: ; preds = %if.else.402, %if.then.401 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] ret { ptr, i64 } %bp } @@ -7380,12 +7389,12 @@ if.then.417: ; preds = %entry if.else.418: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 11 }, { ptr, i64 } %callN) br label %if.merge.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7408,12 +7417,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 4 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7436,12 +7445,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 11 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7464,12 +7473,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 6 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7491,12 +7500,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 5 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7519,12 +7528,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 9 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7547,12 +7556,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 18 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7575,12 +7584,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 5 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7603,12 +7612,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7631,12 +7640,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 4 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7659,12 +7668,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 9 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7687,12 +7696,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 4 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7714,12 +7723,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 8 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7742,12 +7751,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 6 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7769,12 +7778,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 9 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7797,12 +7806,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 7 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7825,12 +7834,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 5 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7853,12 +7862,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 7 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.767, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7881,12 +7890,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 4 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7909,12 +7918,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 7 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7937,12 +7946,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 5 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7965,12 +7974,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 7 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7993,12 +8002,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 9 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -8021,12 +8030,12 @@ if.then.486: ; preds = %entry if.else.487: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 12 }, { ptr, i64 } %callN) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.785, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -8049,12 +8058,12 @@ if.then.489: ; preds = %entry if.else.490: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 6 }, { ptr, i64 } %callN) br label %if.merge.491 if.merge.491: ; preds = %if.else.490, %if.then.489 - %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.788, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -8077,12 +8086,12 @@ if.then.492: ; preds = %entry if.else.493: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 6 }, { ptr, i64 } %callN) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.791, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -8105,12 +8114,12 @@ if.then.495: ; preds = %entry if.else.496: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 7 }, { ptr, i64 } %callN) br label %if.merge.497 if.merge.497: ; preds = %if.else.496, %if.then.495 - %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.794, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -8133,12 +8142,12 @@ if.then.498: ; preds = %entry if.else.499: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.796, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 7 }, { ptr, i64 } %callN) br label %if.merge.500 if.merge.500: ; preds = %if.else.499, %if.then.498 - %bp = phi { ptr, i64 } [ { ptr @str.795, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.797, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -8161,12 +8170,12 @@ if.then.501: ; preds = %entry if.else.502: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.799, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 4 }, { ptr, i64 } %callN) br label %if.merge.503 if.merge.503: ; preds = %if.else.502, %if.then.501 - %bp = phi { ptr, i64 } [ { ptr @str.798, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -8189,12 +8198,12 @@ if.then.504: ; preds = %entry if.else.505: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 6 }, { ptr, i64 } %callN) br label %if.merge.506 if.merge.506: ; preds = %if.else.505, %if.then.504 - %bp = phi { ptr, i64 } [ { ptr @str.801, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.803, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -8217,12 +8226,12 @@ if.then.507: ; preds = %entry if.else.508: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.805, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 5 }, { ptr, i64 } %callN) br label %if.merge.509 if.merge.509: ; preds = %if.else.508, %if.then.507 - %bp = phi { ptr, i64 } [ { ptr @str.804, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.806, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -8245,12 +8254,12 @@ if.then.510: ; preds = %entry if.else.511: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.808, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.811, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 7 }, { ptr, i64 } %callN) br label %if.merge.512 if.merge.512: ; preds = %if.else.511, %if.then.510 - %bp = phi { ptr, i64 } [ { ptr @str.807, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.809, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -8273,12 +8282,12 @@ if.then.513: ; preds = %entry if.else.514: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.812, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.811, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.814, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 7 }, { ptr, i64 } %callN) br label %if.merge.515 if.merge.515: ; preds = %if.else.514, %if.then.513 - %bp = phi { ptr, i64 } [ { ptr @str.810, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.812, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -8294,7 +8303,7 @@ entry: br i1 %lnot, label %if.then.522, label %if.merge.523 if.then.522: ; preds = %entry - ret { ptr, i64 } { ptr @str.813, i64 4 } + ret { ptr, i64 } { ptr @str.815, i64 4 } if.merge.523: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8318,7 +8327,7 @@ entry: br i1 %lnot, label %if.then.524, label %if.merge.525 if.then.524: ; preds = %entry - ret { ptr, i64 } { ptr @str.814, i64 4 } + ret { ptr, i64 } { ptr @str.816, i64 4 } if.merge.525: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8342,7 +8351,7 @@ entry: br i1 %lnot, label %if.then.526, label %if.merge.527 if.then.526: ; preds = %entry - ret { ptr, i64 } { ptr @str.815, i64 4 } + ret { ptr, i64 } { ptr @str.817, i64 4 } if.merge.527: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8366,7 +8375,7 @@ entry: br i1 %lnot, label %if.then.528, label %if.merge.529 if.then.528: ; preds = %entry - ret { ptr, i64 } { ptr @str.816, i64 4 } + ret { ptr, i64 } { ptr @str.818, i64 4 } if.merge.529: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -8474,15 +8483,15 @@ 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_init, align 8 - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.817) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_setWidth_, align 8 - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.818) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_setHeight_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.819) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_width, align 8 + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_setWidth_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.820) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_height, align 8 + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_setHeight_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.821) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_width, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.822) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_height, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.823) store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_area, align 8 ret void } @@ -8494,25 +8503,25 @@ declare ptr @class_getInstanceVariable(ptr, ptr) define internal void @__sx_objc_defined_class_init() { entry: %super_cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_) - %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.822, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.824, i64 0) %0 = call i8 @class_addIvar(ptr %cls, ptr @OBJC_IVAR_NAME_, i64 8, i8 3, ptr @OBJC_IVAR_TYPE_) %metacls = call ptr @object_getClass(ptr %cls) - %sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.823) + %sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.825) %1 = call i1 @class_addMethod(ptr %cls, ptr %sel, ptr @__SxBox_width_imp, ptr @OBJC_METH_VAR_TYPE_) - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.824) - %2 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setWidth_imp, ptr @OBJC_METH_VAR_TYPE_.825) %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.826) - %3 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_height_imp, ptr @OBJC_METH_VAR_TYPE_.827) + %2 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setWidth_imp, ptr @OBJC_METH_VAR_TYPE_.827) %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.828) - %4 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setHeight_imp, ptr @OBJC_METH_VAR_TYPE_.829) + %3 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_height_imp, ptr @OBJC_METH_VAR_TYPE_.829) %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.830) - %5 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_area_imp, ptr @OBJC_METH_VAR_TYPE_.831) + %4 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setHeight_imp, ptr @OBJC_METH_VAR_TYPE_.831) + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.832) + %5 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_area_imp, ptr @OBJC_METH_VAR_TYPE_.833) call void @objc_registerClassPair(ptr %cls) store ptr %cls, ptr @__SxBox_class, align 8 - %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.832) - %6 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxBox_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.833) - %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.834) - %7 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxBox_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.835) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.834) + %6 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxBox_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.835) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.836) + %7 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxBox_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.837) %iv = call ptr @class_getInstanceVariable(ptr %cls, ptr @OBJC_IVAR_NAME_) store ptr %iv, ptr @__SxBox_state_ivar, align 8 ret void @@ -8520,7 +8529,7 @@ entry: define internal void @__sx_objc_class_init() { entry: - %cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_.836) + %cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_.838) store ptr %cls, ptr @OBJC_CLASSLIST_REFERENCES_SxBox, align 8 ret void } diff --git a/examples/expected/1329-ffi-objc-call-03-selector-sharing.ir b/examples/expected/1329-ffi-objc-call-03-selector-sharing.ir index fac4296..750287a 100644 --- a/examples/expected/1329-ffi-objc-call-03-selector-sharing.ir +++ b/examples/expected/1329-ffi-objc-call-03-selector-sharing.ir @@ -3,26 +3,26 @@ @OBJC_SELECTOR_REFERENCES_init = internal global ptr null @OBJC_SELECTOR_REFERENCES_release = internal global ptr null @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.163 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.164 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.165 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.166 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.167 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.168 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.169 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.170 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.171 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.172 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.173 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.174 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.175 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.176 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.177 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.178 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.165 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.166 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.168 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.169 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.170 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.171 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.172 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.173 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.174 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.175 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.176 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.177 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.178 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.179 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.180 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.181 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [5 x i8] c"init\00" -@OBJC_METH_VAR_NAME_.180 = private unnamed_addr constant [8 x i8] c"release\00" +@OBJC_METH_VAR_NAME_.182 = private unnamed_addr constant [8 x i8] c"release\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 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.162, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.164, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.163, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.164, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -614,64 +617,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,118 +1426,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -1564,14 +1573,14 @@ entry: define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.177, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.179, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.178, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.180, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1587,7 +1596,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.179, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.181, i64 3 }) ret { ptr, i64 } %call } @@ -1599,7 +1608,7 @@ 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_init, align 8 - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.180) + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.182) store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_release, align 8 ret void } diff --git a/examples/expected/1332-ffi-objc-call-06-sret-return.ir b/examples/expected/1332-ffi-objc-call-06-sret-return.ir index 842e819..54ebf1b 100644 --- a/examples/expected/1332-ffi-objc-call-06-sret-return.ir +++ b/examples/expected/1332-ffi-objc-call-06-sret-return.ir @@ -2,648 +2,648 @@ @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @OBJC_SELECTOR_REFERENCES_tripleValue = internal global ptr null @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.163 = private unnamed_addr constant [5 x i8] c"true\00", align 1 -@str.164 = private unnamed_addr constant [6 x i8] c"false\00", align 1 -@str.165 = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.166 = private unnamed_addr constant [4 x i8] c"\00", align 1 -@str.167 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.165 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.166 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.167 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.168 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.169 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @__sx_type_is_unsigned = private constant [169 x i1] [i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false] @tag.str = private constant [1 x i8] zeroinitializer -@tag.str.168 = private constant [9 x i8] c"Overflow\00" -@tag.str.169 = private constant [3 x i8] c"Io\00" -@tag.str.170 = private constant [16 x i8] c"UnexpectedToken\00" -@tag.str.171 = private constant [14 x i8] c"UnexpectedEnd\00" -@tag.str.172 = private constant [10 x i8] c"BadEscape\00" -@tag.str.173 = private constant [10 x i8] c"BadNumber\00" -@tag.str.174 = private constant [16 x i8] c"TrailingGarbage\00" -@tag.str.175 = private constant [15 x i8] c"BadControlChar\00" -@tag.str.176 = private constant [15 x i8] c"UnknownCommand\00" -@tag.str.177 = private constant [12 x i8] c"UnknownFlag\00" -@tag.str.178 = private constant [13 x i8] c"MissingValue\00" -@tag.str.179 = private constant [16 x i8] c"MissingRequired\00" -@tag.str.180 = private constant [13 x i8] c"TooManyFlags\00" -@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.168, i64 8 }, { ptr, i64 } { ptr @tag.str.169, i64 2 }, { ptr, i64 } { ptr @tag.str.170, i64 15 }, { ptr, i64 } { ptr @tag.str.171, i64 13 }, { ptr, i64 } { ptr @tag.str.172, i64 9 }, { ptr, i64 } { ptr @tag.str.173, i64 9 }, { ptr, i64 } { ptr @tag.str.174, i64 15 }, { ptr, i64 } { ptr @tag.str.175, i64 14 }, { ptr, i64 } { ptr @tag.str.176, i64 14 }, { ptr, i64 } { ptr @tag.str.177, i64 11 }, { ptr, i64 } { ptr @tag.str.178, i64 12 }, { ptr, i64 } { ptr @tag.str.179, i64 15 }, { ptr, i64 } { ptr @tag.str.180, i64 12 }] +@tag.str.170 = private constant [9 x i8] c"Overflow\00" +@tag.str.171 = private constant [3 x i8] c"Io\00" +@tag.str.172 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.173 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.174 = private constant [10 x i8] c"BadEscape\00" +@tag.str.175 = private constant [10 x i8] c"BadNumber\00" +@tag.str.176 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.177 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.178 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.179 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.180 = private constant [13 x i8] c"MissingValue\00" +@tag.str.181 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.182 = private constant [13 x i8] c"TooManyFlags\00" +@tag_names = private constant [14 x { ptr, i64 }] [{ ptr, i64 } { ptr @tag.str, i64 0 }, { ptr, i64 } { ptr @tag.str.170, i64 8 }, { ptr, i64 } { ptr @tag.str.171, i64 2 }, { ptr, i64 } { ptr @tag.str.172, i64 15 }, { ptr, i64 } { ptr @tag.str.173, i64 13 }, { ptr, i64 } { ptr @tag.str.174, i64 9 }, { ptr, i64 } { ptr @tag.str.175, i64 9 }, { ptr, i64 } { ptr @tag.str.176, i64 15 }, { ptr, i64 } { ptr @tag.str.177, i64 14 }, { ptr, i64 } { ptr @tag.str.178, i64 14 }, { ptr, i64 } { ptr @tag.str.179, i64 11 }, { ptr, i64 } { ptr @tag.str.180, i64 12 }, { ptr, i64 } { ptr @tag.str.181, i64 15 }, { ptr, i64 } { ptr @tag.str.182, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@tn.str.181 = private constant [5 x i8] c"bool\00" -@tn.str.182 = private constant [3 x i8] c"s8\00" -@tn.str.183 = private constant [4 x i8] c"s16\00" -@tn.str.184 = private constant [4 x i8] c"s32\00" -@tn.str.185 = private constant [4 x i8] c"s64\00" -@tn.str.186 = private constant [3 x i8] c"u8\00" -@tn.str.187 = private constant [4 x i8] c"u16\00" -@tn.str.188 = private constant [4 x i8] c"u32\00" -@tn.str.189 = private constant [4 x i8] c"u64\00" -@tn.str.190 = private constant [4 x i8] c"f32\00" -@tn.str.191 = private constant [4 x i8] c"f64\00" -@tn.str.192 = private constant [7 x i8] c"string\00" -@tn.str.193 = private constant [4 x i8] c"Any\00" -@tn.str.194 = private constant [9 x i8] c"noreturn\00" -@tn.str.195 = private constant [6 x i8] c"isize\00" -@tn.str.196 = private constant [6 x i8] c"usize\00" -@tn.str.197 = private constant [5 x i8] c"void\00" -@tn.str.198 = private constant [6 x i8] c"*void\00" -@tn.str.199 = private constant [16 x i8] c"Source_Location\00" -@tn.str.200 = private constant [11 x i8] c"CAllocator\00" -@tn.str.201 = private constant [12 x i8] c"*CAllocator\00" -@tn.str.202 = private constant [4 x i8] c"GPA\00" -@tn.str.203 = private constant [5 x i8] c"*GPA\00" -@tn.str.204 = private constant [11 x i8] c"ArenaChunk\00" -@tn.str.205 = private constant [12 x i8] c"*ArenaChunk\00" -@tn.str.206 = private constant [10 x i8] c"Allocator\00" -@tn.str.207 = private constant [6 x i8] c"Arena\00" -@tn.str.208 = private constant [7 x i8] c"*Arena\00" -@tn.str.209 = private constant [6 x i8] c"[*]u8\00" -@tn.str.210 = private constant [9 x i8] c"BufAlloc\00" -@tn.str.211 = private constant [10 x i8] c"*BufAlloc\00" -@tn.str.212 = private constant [18 x i8] c"TrackingAllocator\00" -@tn.str.213 = private constant [19 x i8] c"*TrackingAllocator\00" -@tn.str.214 = private constant [8 x i8] c"Context\00" -@tn.str.215 = private constant [7 x i8] c"[4]s64\00" -@tn.str.216 = private constant [9 x i8] c"[]string\00" -@tn.str.217 = private constant [9 x i8] c"OpenMode\00" -@tn.str.218 = private constant [9 x i8] c"SeekFrom\00" -@tn.str.219 = private constant [5 x i8] c"File\00" -@tn.str.220 = private constant [6 x i8] c"*File\00" -@tn.str.221 = private constant [6 x i8] c"?File\00" -@tn.str.222 = private constant [8 x i8] c"?string\00" -@tn.str.223 = private constant [11 x i8] c"TraceFrame\00" -@tn.str.224 = private constant [4 x i8] c"*u8\00" -@tn.str.225 = private constant [14 x i8] c"ProcessResult\00" -@tn.str.226 = private constant [15 x i8] c"?ProcessResult\00" -@tn.str.227 = private constant [5 x i8] c"*s32\00" -@tn.str.228 = private constant [9 x i8] c"SockAddr\00" -@tn.str.229 = private constant [10 x i8] c"*SockAddr\00" -@tn.str.230 = private constant [5 x i8] c"*u32\00" -@tn.str.231 = private constant [10 x i8] c"JsonError\00" -@tn.str.232 = private constant [6 x i8] c"Array\00" -@tn.str.233 = private constant [7 x i8] c"Object\00" -@tn.str.234 = private constant [6 x i8] c"Value\00" -@tn.str.235 = private constant [7 x i8] c"Member\00" -@tn.str.236 = private constant [9 x i8] c"[*]Value\00" -@tn.str.237 = private constant [7 x i8] c"*Array\00" -@tn.str.238 = private constant [10 x i8] c"[*]Member\00" -@tn.str.239 = private constant [8 x i8] c"*Object\00" -@tn.str.240 = private constant [5 x i8] c"[]u8\00" -@tn.str.241 = private constant [5 x i8] c"Sink\00" -@tn.str.242 = private constant [6 x i8] c"*Sink\00" -@tn.str.243 = private constant [17 x i8] c"(s64, JsonError)\00" -@tn.str.244 = private constant [15 x i8] c"JsonParseError\00" -@tn.str.245 = private constant [22 x i8] c"(s64, JsonParseError)\00" -@tn.str.246 = private constant [7 x i8] c"Parser\00" -@tn.str.247 = private constant [8 x i8] c"*Parser\00" -@tn.str.248 = private constant [25 x i8] c"(string, JsonParseError)\00" -@tn.str.249 = private constant [24 x i8] c"(Value, JsonParseError)\00" -@tn.str.250 = private constant [16 x i8] c"OperatingSystem\00" -@tn.str.251 = private constant [13 x i8] c"Architecture\00" -@tn.str.252 = private constant [13 x i8] c"BuildOptions\00" -@tn.str.253 = private constant [11 x i8] c"() -> bool\00" -@tn.str.254 = private constant [5 x i8] c"*s64\00" -@tn.str.255 = private constant [9 x i8] c"CliError\00" -@tn.str.256 = private constant [9 x i8] c"FlagSpec\00" -@tn.str.257 = private constant [11 x i8] c"[]FlagSpec\00" -@tn.str.258 = private constant [8 x i8] c"Command\00" -@tn.str.259 = private constant [10 x i8] c"FlagValue\00" -@tn.str.260 = private constant [5 x i8] c"Diag\00" -@tn.str.261 = private constant [14 x i8] c"[16]FlagValue\00" -@tn.str.262 = private constant [7 x i8] c"Parsed\00" -@tn.str.263 = private constant [8 x i8] c"*Parsed\00" -@tn.str.264 = private constant [19 x i8] c"(Parsed, CliError)\00" -@tn.str.265 = private constant [10 x i8] c"[]Command\00" -@tn.str.266 = private constant [6 x i8] c"*Diag\00" -@tn.str.267 = private constant [7 x i8] c"[8]s64\00" -@tn.str.268 = private constant [7 x i8] c"[64]u8\00" -@tn.str.269 = private constant [7 x i8] c"Sha256\00" -@tn.str.270 = private constant [8 x i8] c"*Sha256\00" -@tn.str.271 = private constant [8 x i8] c"?[64]u8\00" -@tn.str.272 = private constant [8 x i8] c"[64]s64\00" -@tn.str.273 = private constant [9 x i8] c"NSString\00" -@tn.str.274 = private constant [10 x i8] c"*NSString\00" -@tn.str.275 = private constant [10 x i8] c"Closure()\00" -@tn.str.276 = private constant [7 x i8] c"Triple\00" -@tn.str.277 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.278 = private constant [7 x i8] c"**void\00" -@tn.str.279 = private constant [6 x i8] c"*bool\00" -@tn.str.280 = private constant [8 x i8] c"*string\00" -@tn.str.281 = private constant [6 x i8] c"[]Any\00" -@tn.str.282 = private constant [5 x i8] c"*Any\00" -@tn.str.283 = private constant [7 x i8] c"[1]Any\00" -@tn.str.284 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.285 = private constant [7 x i8] c"*[]Any\00" -@tn.str.286 = private constant [8 x i8] c"*Triple\00" -@tn.str.287 = private constant [7 x i8] c"[3]Any\00" -@tn.str.288 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.289 = private constant [8 x i8] c"*[4]s64\00" -@tn.str.290 = private constant [5 x i8] c"*f64\00" -@tn.str.291 = private constant [17 x i8] c"*Source_Location\00" -@tn.str.292 = private constant [11 x i8] c"*Allocator\00" -@tn.str.293 = private constant [9 x i8] c"*Context\00" -@tn.str.294 = private constant [12 x i8] c"*TraceFrame\00" -@tn.str.295 = private constant [15 x i8] c"*ProcessResult\00" -@tn.str.296 = private constant [8 x i8] c"*Member\00" -@tn.str.297 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.298 = private constant [10 x i8] c"*FlagSpec\00" -@tn.str.299 = private constant [9 x i8] c"*Command\00" -@tn.str.300 = private constant [11 x i8] c"*FlagValue\00" -@tn.str.301 = private constant [10 x i8] c"*OpenMode\00" -@tn.str.302 = private constant [10 x i8] c"*SeekFrom\00" -@tn.str.303 = private constant [7 x i8] c"*Value\00" -@tn.str.304 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.305 = private constant [14 x i8] c"*Architecture\00" -@tn.str.306 = private constant [15 x i8] c"*[16]FlagValue\00" -@tn.str.307 = private constant [8 x i8] c"*[8]s64\00" -@tn.str.308 = private constant [8 x i8] c"*[64]u8\00" -@tn.str.309 = private constant [9 x i8] c"*[64]s64\00" -@tn.str.310 = private constant [10 x i8] c"*[]string\00" -@tn.str.311 = private constant [6 x i8] c"*[]u8\00" -@tn.str.312 = private constant [12 x i8] c"*[]FlagSpec\00" -@tn.str.313 = private constant [11 x i8] c"*[]Command\00" -@tn.str.314 = private constant [6 x i8] c"**GPA\00" -@tn.str.315 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.316 = private constant [8 x i8] c"**Arena\00" -@tn.str.317 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.318 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.319 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.320 = private constant [7 x i8] c"**File\00" -@tn.str.321 = private constant [5 x i8] c"**u8\00" -@tn.str.322 = private constant [6 x i8] c"**s32\00" -@tn.str.323 = private constant [11 x i8] c"**SockAddr\00" -@tn.str.324 = private constant [6 x i8] c"**u32\00" -@tn.str.325 = private constant [10 x i8] c"*[*]Value\00" -@tn.str.326 = private constant [8 x i8] c"**Array\00" -@tn.str.327 = private constant [11 x i8] c"*[*]Member\00" -@tn.str.328 = private constant [9 x i8] c"**Object\00" -@tn.str.329 = private constant [7 x i8] c"**Sink\00" -@tn.str.330 = private constant [9 x i8] c"**Parser\00" -@tn.str.331 = private constant [6 x i8] c"**s64\00" -@tn.str.332 = private constant [9 x i8] c"**Parsed\00" -@tn.str.333 = private constant [7 x i8] c"**Diag\00" -@tn.str.334 = private constant [9 x i8] c"**Sha256\00" -@tn.str.335 = private constant [11 x i8] c"**NSString\00" -@tn.str.336 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.337 = private constant [8 x i8] c"***void\00" -@tn.str.338 = private constant [7 x i8] c"**bool\00" -@tn.str.339 = private constant [9 x i8] c"**string\00" -@tn.str.340 = private constant [6 x i8] c"**Any\00" -@tn.str.341 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.342 = private constant [8 x i8] c"**[]Any\00" -@tn.str.343 = private constant [9 x i8] c"**Triple\00" -@tn.str.344 = private constant [9 x i8] c"**[3]Any\00" -@tn.str.345 = private constant [7 x i8] c"*?File\00" -@tn.str.346 = private constant [9 x i8] c"*?string\00" -@tn.str.347 = private constant [16 x i8] c"*?ProcessResult\00" -@tn.str.348 = private constant [9 x i8] c"*?[64]u8\00" -@__sx_type_names = private constant [169 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.181, i64 4 }, { ptr, i64 } { ptr @tn.str.182, i64 2 }, { ptr, i64 } { ptr @tn.str.183, i64 3 }, { ptr, i64 } { ptr @tn.str.184, i64 3 }, { ptr, i64 } { ptr @tn.str.185, i64 3 }, { ptr, i64 } { ptr @tn.str.186, i64 2 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 3 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 6 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 8 }, { ptr, i64 } { ptr @tn.str.195, i64 5 }, { ptr, i64 } { ptr @tn.str.196, i64 5 }, { ptr, i64 } { ptr @tn.str.197, i64 4 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 15 }, { ptr, i64 } { ptr @tn.str.200, i64 10 }, { ptr, i64 } { ptr @tn.str.201, i64 11 }, { ptr, i64 } { ptr @tn.str.202, i64 3 }, { ptr, i64 } { ptr @tn.str.203, i64 4 }, { ptr, i64 } { ptr @tn.str.204, i64 10 }, { ptr, i64 } { ptr @tn.str.205, i64 11 }, { ptr, i64 } { ptr @tn.str.206, i64 9 }, { ptr, i64 } { ptr @tn.str.207, i64 5 }, { ptr, i64 } { ptr @tn.str.208, i64 6 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 8 }, { ptr, i64 } { ptr @tn.str.211, i64 9 }, { ptr, i64 } { ptr @tn.str.212, i64 17 }, { ptr, i64 } { ptr @tn.str.213, i64 18 }, { ptr, i64 } { ptr @tn.str.214, i64 7 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 8 }, { ptr, i64 } { ptr @tn.str.217, i64 8 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 4 }, { ptr, i64 } { ptr @tn.str.220, i64 5 }, { ptr, i64 } { ptr @tn.str.221, i64 5 }, { ptr, i64 } { ptr @tn.str.222, i64 7 }, { ptr, i64 } { ptr @tn.str.223, i64 10 }, { ptr, i64 } { ptr @tn.str.224, i64 3 }, { ptr, i64 } { ptr @tn.str.225, i64 13 }, { ptr, i64 } { ptr @tn.str.226, i64 14 }, { ptr, i64 } { ptr @tn.str.227, i64 4 }, { ptr, i64 } { ptr @tn.str.228, i64 8 }, { ptr, i64 } { ptr @tn.str.229, i64 9 }, { ptr, i64 } { ptr @tn.str.230, i64 4 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 5 }, { ptr, i64 } { ptr @tn.str.233, i64 6 }, { ptr, i64 } { ptr @tn.str.234, i64 5 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 8 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 9 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 4 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 5 }, { ptr, i64 } { ptr @tn.str.243, i64 16 }, { ptr, i64 } { ptr @tn.str.244, i64 14 }, { ptr, i64 } { ptr @tn.str.245, i64 21 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 24 }, { ptr, i64 } { ptr @tn.str.249, i64 23 }, { ptr, i64 } { ptr @tn.str.250, i64 15 }, { ptr, i64 } { ptr @tn.str.251, i64 12 }, { ptr, i64 } { ptr @tn.str.252, i64 12 }, { ptr, i64 } { ptr @tn.str.253, i64 10 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 8 }, { ptr, i64 } { ptr @tn.str.256, i64 8 }, { ptr, i64 } { ptr @tn.str.257, i64 10 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 4 }, { ptr, i64 } { ptr @tn.str.261, i64 13 }, { ptr, i64 } { ptr @tn.str.262, i64 6 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 18 }, { ptr, i64 } { ptr @tn.str.265, i64 9 }, { ptr, i64 } { ptr @tn.str.266, i64 5 }, { ptr, i64 } { ptr @tn.str.267, i64 6 }, { ptr, i64 } { ptr @tn.str.268, i64 6 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 7 }, { ptr, i64 } { ptr @tn.str.271, i64 7 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 8 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 9 }, { ptr, i64 } { ptr @tn.str.276, i64 6 }, { ptr, i64 } { ptr @tn.str.277, i64 12 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 5 }, { ptr, i64 } { ptr @tn.str.280, i64 7 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 4 }, { ptr, i64 } { ptr @tn.str.283, i64 6 }, { ptr, i64 } { ptr @tn.str.284, i64 7 }, { ptr, i64 } { ptr @tn.str.285, i64 6 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 7 }, { ptr, i64 } { ptr @tn.str.290, i64 4 }, { ptr, i64 } { ptr @tn.str.291, i64 16 }, { ptr, i64 } { ptr @tn.str.292, i64 10 }, { ptr, i64 } { ptr @tn.str.293, i64 8 }, { ptr, i64 } { ptr @tn.str.294, i64 11 }, { ptr, i64 } { ptr @tn.str.295, i64 14 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 13 }, { ptr, i64 } { ptr @tn.str.298, i64 9 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 10 }, { ptr, i64 } { ptr @tn.str.301, i64 9 }, { ptr, i64 } { ptr @tn.str.302, i64 9 }, { ptr, i64 } { ptr @tn.str.303, i64 6 }, { ptr, i64 } { ptr @tn.str.304, i64 16 }, { ptr, i64 } { ptr @tn.str.305, i64 13 }, { ptr, i64 } { ptr @tn.str.306, i64 14 }, { ptr, i64 } { ptr @tn.str.307, i64 7 }, { ptr, i64 } { ptr @tn.str.308, i64 7 }, { ptr, i64 } { ptr @tn.str.309, i64 8 }, { ptr, i64 } { ptr @tn.str.310, i64 9 }, { ptr, i64 } { ptr @tn.str.311, i64 5 }, { ptr, i64 } { ptr @tn.str.312, i64 11 }, { ptr, i64 } { ptr @tn.str.313, i64 10 }, { ptr, i64 } { ptr @tn.str.314, i64 5 }, { ptr, i64 } { ptr @tn.str.315, i64 12 }, { ptr, i64 } { ptr @tn.str.316, i64 7 }, { ptr, i64 } { ptr @tn.str.317, i64 6 }, { ptr, i64 } { ptr @tn.str.318, i64 10 }, { ptr, i64 } { ptr @tn.str.319, i64 19 }, { ptr, i64 } { ptr @tn.str.320, i64 6 }, { ptr, i64 } { ptr @tn.str.321, i64 4 }, { ptr, i64 } { ptr @tn.str.322, i64 5 }, { ptr, i64 } { ptr @tn.str.323, i64 10 }, { ptr, i64 } { ptr @tn.str.324, i64 5 }, { ptr, i64 } { ptr @tn.str.325, i64 9 }, { ptr, i64 } { ptr @tn.str.326, i64 7 }, { ptr, i64 } { ptr @tn.str.327, i64 10 }, { ptr, i64 } { ptr @tn.str.328, i64 8 }, { ptr, i64 } { ptr @tn.str.329, i64 6 }, { ptr, i64 } { ptr @tn.str.330, i64 8 }, { ptr, i64 } { ptr @tn.str.331, i64 5 }, { ptr, i64 } { ptr @tn.str.332, i64 8 }, { ptr, i64 } { ptr @tn.str.333, i64 6 }, { ptr, i64 } { ptr @tn.str.334, i64 8 }, { ptr, i64 } { ptr @tn.str.335, i64 10 }, { ptr, i64 } { ptr @tn.str.336, i64 13 }, { ptr, i64 } { ptr @tn.str.337, i64 7 }, { ptr, i64 } { ptr @tn.str.338, i64 6 }, { ptr, i64 } { ptr @tn.str.339, i64 8 }, { ptr, i64 } { ptr @tn.str.340, i64 5 }, { ptr, i64 } { ptr @tn.str.341, i64 8 }, { ptr, i64 } { ptr @tn.str.342, i64 7 }, { ptr, i64 } { ptr @tn.str.343, i64 8 }, { ptr, i64 } { ptr @tn.str.344, i64 8 }, { ptr, i64 } { ptr @tn.str.345, i64 6 }, { ptr, i64 } { ptr @tn.str.346, i64 8 }, { ptr, i64 } { ptr @tn.str.347, i64 15 }, { ptr, i64 } { ptr @tn.str.348, i64 8 }] -@str.349 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.350 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.183 = private constant [5 x i8] c"bool\00" +@tn.str.184 = private constant [3 x i8] c"s8\00" +@tn.str.185 = private constant [4 x i8] c"s16\00" +@tn.str.186 = private constant [4 x i8] c"s32\00" +@tn.str.187 = private constant [4 x i8] c"s64\00" +@tn.str.188 = private constant [3 x i8] c"u8\00" +@tn.str.189 = private constant [4 x i8] c"u16\00" +@tn.str.190 = private constant [4 x i8] c"u32\00" +@tn.str.191 = private constant [4 x i8] c"u64\00" +@tn.str.192 = private constant [4 x i8] c"f32\00" +@tn.str.193 = private constant [4 x i8] c"f64\00" +@tn.str.194 = private constant [7 x i8] c"string\00" +@tn.str.195 = private constant [4 x i8] c"Any\00" +@tn.str.196 = private constant [9 x i8] c"noreturn\00" +@tn.str.197 = private constant [6 x i8] c"isize\00" +@tn.str.198 = private constant [6 x i8] c"usize\00" +@tn.str.199 = private constant [5 x i8] c"void\00" +@tn.str.200 = private constant [6 x i8] c"*void\00" +@tn.str.201 = private constant [16 x i8] c"Source_Location\00" +@tn.str.202 = private constant [10 x i8] c"Allocator\00" +@tn.str.203 = private constant [11 x i8] c"CAllocator\00" +@tn.str.204 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.205 = private constant [4 x i8] c"GPA\00" +@tn.str.206 = private constant [5 x i8] c"*GPA\00" +@tn.str.207 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.208 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.209 = private constant [6 x i8] c"Arena\00" +@tn.str.210 = private constant [7 x i8] c"*Arena\00" +@tn.str.211 = private constant [6 x i8] c"[*]u8\00" +@tn.str.212 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.213 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.214 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.215 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.216 = private constant [8 x i8] c"Context\00" +@tn.str.217 = private constant [7 x i8] c"[4]s64\00" +@tn.str.218 = private constant [9 x i8] c"[]string\00" +@tn.str.219 = private constant [9 x i8] c"OpenMode\00" +@tn.str.220 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.221 = private constant [5 x i8] c"File\00" +@tn.str.222 = private constant [6 x i8] c"*File\00" +@tn.str.223 = private constant [6 x i8] c"?File\00" +@tn.str.224 = private constant [8 x i8] c"?string\00" +@tn.str.225 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.226 = private constant [4 x i8] c"*u8\00" +@tn.str.227 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.228 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.229 = private constant [5 x i8] c"*s32\00" +@tn.str.230 = private constant [9 x i8] c"SockAddr\00" +@tn.str.231 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.232 = private constant [5 x i8] c"*u32\00" +@tn.str.233 = private constant [10 x i8] c"JsonError\00" +@tn.str.234 = private constant [6 x i8] c"Array\00" +@tn.str.235 = private constant [7 x i8] c"Object\00" +@tn.str.236 = private constant [6 x i8] c"Value\00" +@tn.str.237 = private constant [7 x i8] c"Member\00" +@tn.str.238 = private constant [9 x i8] c"[*]Value\00" +@tn.str.239 = private constant [7 x i8] c"*Array\00" +@tn.str.240 = private constant [10 x i8] c"[*]Member\00" +@tn.str.241 = private constant [8 x i8] c"*Object\00" +@tn.str.242 = private constant [5 x i8] c"[]u8\00" +@tn.str.243 = private constant [5 x i8] c"Sink\00" +@tn.str.244 = private constant [6 x i8] c"*Sink\00" +@tn.str.245 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.246 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.247 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.248 = private constant [7 x i8] c"Parser\00" +@tn.str.249 = private constant [8 x i8] c"*Parser\00" +@tn.str.250 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.251 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.252 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.253 = private constant [13 x i8] c"Architecture\00" +@tn.str.254 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.255 = private constant [11 x i8] c"() -> bool\00" +@tn.str.256 = private constant [5 x i8] c"*s64\00" +@tn.str.257 = private constant [9 x i8] c"CliError\00" +@tn.str.258 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.259 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.260 = private constant [8 x i8] c"Command\00" +@tn.str.261 = private constant [10 x i8] c"FlagValue\00" +@tn.str.262 = private constant [5 x i8] c"Diag\00" +@tn.str.263 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.264 = private constant [7 x i8] c"Parsed\00" +@tn.str.265 = private constant [8 x i8] c"*Parsed\00" +@tn.str.266 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.267 = private constant [10 x i8] c"[]Command\00" +@tn.str.268 = private constant [6 x i8] c"*Diag\00" +@tn.str.269 = private constant [7 x i8] c"[8]s64\00" +@tn.str.270 = private constant [7 x i8] c"[64]u8\00" +@tn.str.271 = private constant [7 x i8] c"Sha256\00" +@tn.str.272 = private constant [8 x i8] c"*Sha256\00" +@tn.str.273 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.274 = private constant [8 x i8] c"[64]s64\00" +@tn.str.275 = private constant [9 x i8] c"NSString\00" +@tn.str.276 = private constant [10 x i8] c"*NSString\00" +@tn.str.277 = private constant [10 x i8] c"Closure()\00" +@tn.str.278 = private constant [7 x i8] c"Triple\00" +@tn.str.279 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.280 = private constant [7 x i8] c"**void\00" +@tn.str.281 = private constant [6 x i8] c"*bool\00" +@tn.str.282 = private constant [8 x i8] c"*string\00" +@tn.str.283 = private constant [6 x i8] c"[]Any\00" +@tn.str.284 = private constant [5 x i8] c"*Any\00" +@tn.str.285 = private constant [7 x i8] c"[1]Any\00" +@tn.str.286 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.287 = private constant [7 x i8] c"*[]Any\00" +@tn.str.288 = private constant [8 x i8] c"*Triple\00" +@tn.str.289 = private constant [7 x i8] c"[3]Any\00" +@tn.str.290 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.291 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.292 = private constant [5 x i8] c"*f64\00" +@tn.str.293 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.294 = private constant [11 x i8] c"*Allocator\00" +@tn.str.295 = private constant [9 x i8] c"*Context\00" +@tn.str.296 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.297 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.298 = private constant [8 x i8] c"*Member\00" +@tn.str.299 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.300 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.301 = private constant [9 x i8] c"*Command\00" +@tn.str.302 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.303 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.304 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.305 = private constant [7 x i8] c"*Value\00" +@tn.str.306 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.307 = private constant [14 x i8] c"*Architecture\00" +@tn.str.308 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.309 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.310 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.311 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.312 = private constant [10 x i8] c"*[]string\00" +@tn.str.313 = private constant [6 x i8] c"*[]u8\00" +@tn.str.314 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.315 = private constant [11 x i8] c"*[]Command\00" +@tn.str.316 = private constant [6 x i8] c"**GPA\00" +@tn.str.317 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.318 = private constant [8 x i8] c"**Arena\00" +@tn.str.319 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.320 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.321 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.322 = private constant [7 x i8] c"**File\00" +@tn.str.323 = private constant [5 x i8] c"**u8\00" +@tn.str.324 = private constant [6 x i8] c"**s32\00" +@tn.str.325 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.326 = private constant [6 x i8] c"**u32\00" +@tn.str.327 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.328 = private constant [8 x i8] c"**Array\00" +@tn.str.329 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.330 = private constant [9 x i8] c"**Object\00" +@tn.str.331 = private constant [7 x i8] c"**Sink\00" +@tn.str.332 = private constant [9 x i8] c"**Parser\00" +@tn.str.333 = private constant [6 x i8] c"**s64\00" +@tn.str.334 = private constant [9 x i8] c"**Parsed\00" +@tn.str.335 = private constant [7 x i8] c"**Diag\00" +@tn.str.336 = private constant [9 x i8] c"**Sha256\00" +@tn.str.337 = private constant [11 x i8] c"**NSString\00" +@tn.str.338 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.339 = private constant [8 x i8] c"***void\00" +@tn.str.340 = private constant [7 x i8] c"**bool\00" +@tn.str.341 = private constant [9 x i8] c"**string\00" +@tn.str.342 = private constant [6 x i8] c"**Any\00" +@tn.str.343 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.344 = private constant [8 x i8] c"**[]Any\00" +@tn.str.345 = private constant [9 x i8] c"**Triple\00" +@tn.str.346 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.347 = private constant [7 x i8] c"*?File\00" +@tn.str.348 = private constant [9 x i8] c"*?string\00" +@tn.str.349 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.350 = private constant [9 x i8] c"*?[64]u8\00" +@__sx_type_names = private constant [169 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.183, i64 4 }, { ptr, i64 } { ptr @tn.str.184, i64 2 }, { ptr, i64 } { ptr @tn.str.185, i64 3 }, { ptr, i64 } { ptr @tn.str.186, i64 3 }, { ptr, i64 } { ptr @tn.str.187, i64 3 }, { ptr, i64 } { ptr @tn.str.188, i64 2 }, { ptr, i64 } { ptr @tn.str.189, i64 3 }, { ptr, i64 } { ptr @tn.str.190, i64 3 }, { ptr, i64 } { ptr @tn.str.191, i64 3 }, { ptr, i64 } { ptr @tn.str.192, i64 3 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 6 }, { ptr, i64 } { ptr @tn.str.195, i64 3 }, { ptr, i64 } { ptr @tn.str.196, i64 8 }, { ptr, i64 } { ptr @tn.str.197, i64 5 }, { ptr, i64 } { ptr @tn.str.198, i64 5 }, { ptr, i64 } { ptr @tn.str.199, i64 4 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 15 }, { ptr, i64 } { ptr @tn.str.202, i64 9 }, { ptr, i64 } { ptr @tn.str.203, i64 10 }, { ptr, i64 } { ptr @tn.str.204, i64 11 }, { ptr, i64 } { ptr @tn.str.205, i64 3 }, { ptr, i64 } { ptr @tn.str.206, i64 4 }, { ptr, i64 } { ptr @tn.str.207, i64 10 }, { ptr, i64 } { ptr @tn.str.208, i64 11 }, { ptr, i64 } { ptr @tn.str.209, i64 5 }, { ptr, i64 } { ptr @tn.str.210, i64 6 }, { ptr, i64 } { ptr @tn.str.211, i64 5 }, { ptr, i64 } { ptr @tn.str.212, i64 8 }, { ptr, i64 } { ptr @tn.str.213, i64 9 }, { ptr, i64 } { ptr @tn.str.214, i64 17 }, { ptr, i64 } { ptr @tn.str.215, i64 18 }, { ptr, i64 } { ptr @tn.str.216, i64 7 }, { ptr, i64 } { ptr @tn.str.217, i64 6 }, { ptr, i64 } { ptr @tn.str.218, i64 8 }, { ptr, i64 } { ptr @tn.str.219, i64 8 }, { ptr, i64 } { ptr @tn.str.220, i64 8 }, { ptr, i64 } { ptr @tn.str.221, i64 4 }, { ptr, i64 } { ptr @tn.str.222, i64 5 }, { ptr, i64 } { ptr @tn.str.223, i64 5 }, { ptr, i64 } { ptr @tn.str.224, i64 7 }, { ptr, i64 } { ptr @tn.str.225, i64 10 }, { ptr, i64 } { ptr @tn.str.226, i64 3 }, { ptr, i64 } { ptr @tn.str.227, i64 13 }, { ptr, i64 } { ptr @tn.str.228, i64 14 }, { ptr, i64 } { ptr @tn.str.229, i64 4 }, { ptr, i64 } { ptr @tn.str.230, i64 8 }, { ptr, i64 } { ptr @tn.str.231, i64 9 }, { ptr, i64 } { ptr @tn.str.232, i64 4 }, { ptr, i64 } { ptr @tn.str.233, i64 9 }, { ptr, i64 } { ptr @tn.str.234, i64 5 }, { ptr, i64 } { ptr @tn.str.235, i64 6 }, { ptr, i64 } { ptr @tn.str.236, i64 5 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 8 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 9 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { ptr, i64 } { ptr @tn.str.244, i64 5 }, { ptr, i64 } { ptr @tn.str.245, i64 16 }, { ptr, i64 } { ptr @tn.str.246, i64 14 }, { ptr, i64 } { ptr @tn.str.247, i64 21 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { ptr, i64 } { ptr @tn.str.250, i64 24 }, { ptr, i64 } { ptr @tn.str.251, i64 23 }, { ptr, i64 } { ptr @tn.str.252, i64 15 }, { ptr, i64 } { ptr @tn.str.253, i64 12 }, { ptr, i64 } { ptr @tn.str.254, i64 12 }, { ptr, i64 } { ptr @tn.str.255, i64 10 }, { ptr, i64 } { ptr @tn.str.256, i64 4 }, { ptr, i64 } { ptr @tn.str.257, i64 8 }, { ptr, i64 } { ptr @tn.str.258, i64 8 }, { ptr, i64 } { ptr @tn.str.259, i64 10 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 4 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 6 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 18 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 5 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 6 }, { ptr, i64 } { ptr @tn.str.271, i64 6 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 7 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 8 }, { ptr, i64 } { ptr @tn.str.276, i64 9 }, { ptr, i64 } { ptr @tn.str.277, i64 9 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 12 }, { ptr, i64 } { ptr @tn.str.280, i64 6 }, { ptr, i64 } { ptr @tn.str.281, i64 5 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 4 }, { ptr, i64 } { ptr @tn.str.285, i64 6 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 6 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 7 }, { ptr, i64 } { ptr @tn.str.292, i64 4 }, { ptr, i64 } { ptr @tn.str.293, i64 16 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 11 }, { ptr, i64 } { ptr @tn.str.297, i64 14 }, { ptr, i64 } { ptr @tn.str.298, i64 7 }, { ptr, i64 } { ptr @tn.str.299, i64 13 }, { ptr, i64 } { ptr @tn.str.300, i64 9 }, { ptr, i64 } { ptr @tn.str.301, i64 8 }, { ptr, i64 } { ptr @tn.str.302, i64 10 }, { ptr, i64 } { ptr @tn.str.303, i64 9 }, { ptr, i64 } { ptr @tn.str.304, i64 9 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 16 }, { ptr, i64 } { ptr @tn.str.307, i64 13 }, { ptr, i64 } { ptr @tn.str.308, i64 14 }, { ptr, i64 } { ptr @tn.str.309, i64 7 }, { ptr, i64 } { ptr @tn.str.310, i64 7 }, { ptr, i64 } { ptr @tn.str.311, i64 8 }, { ptr, i64 } { ptr @tn.str.312, i64 9 }, { ptr, i64 } { ptr @tn.str.313, i64 5 }, { ptr, i64 } { ptr @tn.str.314, i64 11 }, { ptr, i64 } { ptr @tn.str.315, i64 10 }, { ptr, i64 } { ptr @tn.str.316, i64 5 }, { ptr, i64 } { ptr @tn.str.317, i64 12 }, { ptr, i64 } { ptr @tn.str.318, i64 7 }, { ptr, i64 } { ptr @tn.str.319, i64 6 }, { ptr, i64 } { ptr @tn.str.320, i64 10 }, { ptr, i64 } { ptr @tn.str.321, i64 19 }, { ptr, i64 } { ptr @tn.str.322, i64 6 }, { ptr, i64 } { ptr @tn.str.323, i64 4 }, { ptr, i64 } { ptr @tn.str.324, i64 5 }, { ptr, i64 } { ptr @tn.str.325, i64 10 }, { ptr, i64 } { ptr @tn.str.326, i64 5 }, { ptr, i64 } { ptr @tn.str.327, i64 9 }, { ptr, i64 } { ptr @tn.str.328, i64 7 }, { ptr, i64 } { ptr @tn.str.329, i64 10 }, { ptr, i64 } { ptr @tn.str.330, i64 8 }, { ptr, i64 } { ptr @tn.str.331, i64 6 }, { ptr, i64 } { ptr @tn.str.332, i64 8 }, { ptr, i64 } { ptr @tn.str.333, i64 5 }, { ptr, i64 } { ptr @tn.str.334, i64 8 }, { ptr, i64 } { ptr @tn.str.335, i64 6 }, { ptr, i64 } { ptr @tn.str.336, i64 8 }, { ptr, i64 } { ptr @tn.str.337, i64 10 }, { ptr, i64 } { ptr @tn.str.338, i64 13 }, { ptr, i64 } { ptr @tn.str.339, i64 7 }, { ptr, i64 } { ptr @tn.str.340, i64 6 }, { ptr, i64 } { ptr @tn.str.341, i64 8 }, { ptr, i64 } { ptr @tn.str.342, i64 5 }, { ptr, i64 } { ptr @tn.str.343, i64 8 }, { ptr, i64 } { ptr @tn.str.344, i64 7 }, { ptr, i64 } { ptr @tn.str.345, i64 8 }, { ptr, i64 } { ptr @tn.str.346, i64 8 }, { ptr, i64 } { ptr @tn.str.347, i64 6 }, { ptr, i64 } { ptr @tn.str.348, i64 8 }, { ptr, i64 } { ptr @tn.str.349, i64 15 }, { ptr, i64 } { ptr @tn.str.350, i64 8 }] @str.351 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.352 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.353 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.354 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.355 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.356 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.357 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.358 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.359 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.360 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.361 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.362 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.363 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.364 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.365 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.366 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.367 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.368 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.369 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.370 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 -@str.371 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1 -@str.372 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1 -@str.373 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", align 1 -@str.374 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 -@str.375 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.355 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.356 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.357 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.358 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.359 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.360 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.361 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.362 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.363 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.364 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.365 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.366 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.367 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.368 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.369 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.370 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.371 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.372 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 +@str.373 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1 +@str.374 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1 +@str.375 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", align 1 @str.376 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 -@str.377 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 -@str.378 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.377 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.378 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 @str.379 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 -@str.380 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 -@str.381 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.382 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.383 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.380 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.381 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 +@str.382 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.383 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.384 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.385 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@fld.str.384 = private constant [5 x i8] c"line\00" -@fld.str.385 = private constant [4 x i8] c"col\00" -@fld.str.386 = private constant [5 x i8] c"func\00" -@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.384, i64 4 }, { ptr, i64 } { ptr @fld.str.385, i64 3 }, { ptr, i64 } { ptr @fld.str.386, i64 4 }] -@str.387 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.388 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.389 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.390 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.391 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.392 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.394 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.395 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.396 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.397 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.398 = private constant [12 x i8] c"alloc_count\00" -@field_names.399 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 11 }] -@str.400 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.401 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.402 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.403 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.404 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.405 = private constant [5 x i8] c"next\00" -@fld.str.406 = private constant [4 x i8] c"cap\00" -@field_names.407 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.405, i64 4 }, { ptr, i64 } { ptr @fld.str.406, i64 3 }] -@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.409 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.410 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.411 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.412 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.413 = private constant [4 x i8] c"ctx\00" -@fld.str.414 = private constant [12 x i8] c"alloc_bytes\00" -@fld.str.415 = private constant [14 x i8] c"dealloc_bytes\00" -@field_names.416 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.413, i64 3 }, { ptr, i64 } { ptr @fld.str.414, i64 11 }, { ptr, i64 } { ptr @fld.str.415, i64 13 }] -@str.417 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.418 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.419 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.420 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.421 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.422 = private constant [6 x i8] c"first\00" -@fld.str.423 = private constant [10 x i8] c"end_index\00" -@fld.str.424 = private constant [7 x i8] c"parent\00" -@field_names.425 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.422, i64 5 }, { ptr, i64 } { ptr @fld.str.423, i64 9 }, { ptr, i64 } { ptr @fld.str.424, i64 6 }] -@str.426 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.427 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.428 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.429 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.430 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.431 = private constant [4 x i8] c"buf\00" -@fld.str.432 = private constant [4 x i8] c"len\00" -@fld.str.433 = private constant [4 x i8] c"pos\00" -@field_names.434 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.431, i64 3 }, { ptr, i64 } { ptr @fld.str.432, i64 3 }, { ptr, i64 } { ptr @fld.str.433, i64 3 }] -@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.436 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.437 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.438 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.439 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.440 = private constant [7 x i8] c"parent\00" -@fld.str.441 = private constant [12 x i8] c"alloc_count\00" -@fld.str.442 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.443 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.444 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 6 }, { ptr, i64 } { ptr @fld.str.441, i64 11 }, { ptr, i64 } { ptr @fld.str.442, i64 13 }, { ptr, i64 } { ptr @fld.str.443, i64 17 }] -@str.445 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.446 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.447 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.448 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.449 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.450 = private constant [10 x i8] c"allocator\00" -@fld.str.451 = private constant [5 x i8] c"data\00" -@field_names.452 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.450, i64 9 }, { ptr, i64 } { ptr @fld.str.451, i64 4 }] -@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.454 = private unnamed_addr constant [5 x i8] c"File\00", align 1 -@str.455 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.456 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.457 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.458 = private constant [3 x i8] c"fd\00" -@field_names.459 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 2 }] -@str.460 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.461 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 -@str.462 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.463 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.464 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.465 = private constant [5 x i8] c"file\00" -@fld.str.466 = private constant [5 x i8] c"line\00" -@fld.str.467 = private constant [4 x i8] c"col\00" -@fld.str.468 = private constant [5 x i8] c"func\00" -@fld.str.469 = private constant [10 x i8] c"line_text\00" -@field_names.470 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.465, i64 4 }, { ptr, i64 } { ptr @fld.str.466, i64 4 }, { ptr, i64 } { ptr @fld.str.467, i64 3 }, { ptr, i64 } { ptr @fld.str.468, i64 4 }, { ptr, i64 } { ptr @fld.str.469, i64 9 }] -@str.471 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.472 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 -@str.473 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.474 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.475 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.476 = private constant [10 x i8] c"exit_code\00" -@fld.str.477 = private constant [7 x i8] c"stdout\00" -@field_names.478 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.476, i64 9 }, { ptr, i64 } { ptr @fld.str.477, i64 6 }] -@str.479 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.480 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 -@str.481 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.482 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.483 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.484 = private constant [8 x i8] c"sin_len\00" -@fld.str.485 = private constant [11 x i8] c"sin_family\00" -@fld.str.486 = private constant [9 x i8] c"sin_port\00" -@fld.str.487 = private constant [9 x i8] c"sin_addr\00" -@fld.str.488 = private constant [9 x i8] c"sin_zero\00" -@field_names.489 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.484, i64 7 }, { ptr, i64 } { ptr @fld.str.485, i64 10 }, { ptr, i64 } { ptr @fld.str.486, i64 8 }, { ptr, i64 } { ptr @fld.str.487, i64 8 }, { ptr, i64 } { ptr @fld.str.488, i64 8 }] -@str.490 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.491 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 -@str.492 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.493 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.494 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.495 = private constant [6 x i8] c"items\00" -@fld.str.496 = private constant [4 x i8] c"len\00" -@fld.str.497 = private constant [4 x i8] c"cap\00" -@field_names.498 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.495, i64 5 }, { ptr, i64 } { ptr @fld.str.496, i64 3 }, { ptr, i64 } { ptr @fld.str.497, i64 3 }] -@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.500 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 -@str.501 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.502 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.503 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.504 = private constant [6 x i8] c"items\00" -@fld.str.505 = private constant [4 x i8] c"len\00" -@fld.str.506 = private constant [4 x i8] c"cap\00" -@field_names.507 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.504, i64 5 }, { ptr, i64 } { ptr @fld.str.505, i64 3 }, { ptr, i64 } { ptr @fld.str.506, i64 3 }] -@str.508 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.509 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 -@str.510 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.511 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.512 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.513 = private constant [4 x i8] c"key\00" -@fld.str.514 = private constant [4 x i8] c"val\00" -@field_names.515 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.513, i64 3 }, { ptr, i64 } { ptr @fld.str.514, i64 3 }] -@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.517 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 -@str.518 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.519 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.520 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.521 = private constant [4 x i8] c"dst\00" -@fld.str.522 = private constant [4 x i8] c"pos\00" -@fld.str.523 = private constant [5 x i8] c"file\00" -@field_names.524 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 3 }, { ptr, i64 } { ptr @fld.str.522, i64 3 }, { ptr, i64 } { ptr @fld.str.523, i64 4 }] -@str.525 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.526 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 -@str.527 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.528 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.529 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.530 = private constant [4 x i8] c"src\00" -@fld.str.531 = private constant [4 x i8] c"pos\00" -@fld.str.532 = private constant [6 x i8] c"alloc\00" -@field_names.533 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 3 }, { ptr, i64 } { ptr @fld.str.531, i64 3 }, { ptr, i64 } { ptr @fld.str.532, i64 5 }] -@str.534 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.535 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.536 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.537 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.538 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.539 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.540 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.541 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 -@str.542 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.543 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.544 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.545 = private constant [5 x i8] c"name\00" -@fld.str.546 = private constant [12 x i8] c"takes_value\00" -@fld.str.547 = private constant [9 x i8] c"required\00" -@field_names.548 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 11 }, { ptr, i64 } { ptr @fld.str.547, i64 8 }] -@str.549 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.550 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 -@str.551 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.552 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.553 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.554 = private constant [6 x i8] c"group\00" -@fld.str.555 = private constant [8 x i8] c"command\00" -@fld.str.556 = private constant [6 x i8] c"flags\00" -@field_names.557 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.554, i64 5 }, { ptr, i64 } { ptr @fld.str.555, i64 7 }, { ptr, i64 } { ptr @fld.str.556, i64 5 }] -@str.558 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.559 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 -@str.560 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.561 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.562 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.563 = private constant [4 x i8] c"set\00" -@fld.str.564 = private constant [6 x i8] c"value\00" -@field_names.565 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.563, i64 3 }, { ptr, i64 } { ptr @fld.str.564, i64 5 }] -@str.566 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.567 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 -@str.568 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.569 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.570 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.571 = private constant [6 x i8] c"index\00" -@fld.str.572 = private constant [6 x i8] c"token\00" -@field_names.573 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 5 }] -@str.574 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.575 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 -@str.576 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.577 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.578 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.579 = private constant [6 x i8] c"group\00" -@fld.str.580 = private constant [8 x i8] c"command\00" -@fld.str.581 = private constant [10 x i8] c"cmd_index\00" -@fld.str.582 = private constant [5 x i8] c"json\00" -@fld.str.583 = private constant [5 x i8] c"rest\00" -@fld.str.584 = private constant [5 x i8] c"spec\00" -@fld.str.585 = private constant [7 x i8] c"values\00" -@field_names.586 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 7 }, { ptr, i64 } { ptr @fld.str.581, i64 9 }, { ptr, i64 } { ptr @fld.str.582, i64 4 }, { ptr, i64 } { ptr @fld.str.583, i64 4 }, { ptr, i64 } { ptr @fld.str.584, i64 4 }, { ptr, i64 } { ptr @fld.str.585, i64 6 }] -@str.587 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.588 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 -@str.589 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.590 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.591 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.592 = private constant [2 x i8] c"h\00" -@fld.str.593 = private constant [4 x i8] c"buf\00" -@fld.str.594 = private constant [8 x i8] c"buf_len\00" -@fld.str.595 = private constant [10 x i8] c"total_len\00" -@field_names.596 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.592, i64 1 }, { ptr, i64 } { ptr @fld.str.593, i64 3 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 9 }] -@str.597 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.598 = private unnamed_addr constant [9 x i8] c"NSString\00", align 1 -@str.599 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.600 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.601 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.602 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.603 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.604 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1 -@str.605 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.606 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.607 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.608 = private constant [2 x i8] c"a\00" -@fld.str.609 = private constant [2 x i8] c"b\00" -@fld.str.610 = private constant [2 x i8] c"c\00" -@field_names.611 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.608, i64 1 }, { ptr, i64 } { ptr @fld.str.609, i64 1 }, { ptr, i64 } { ptr @fld.str.610, i64 1 }] -@str.612 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.613 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.614 = private constant [5 x i8] c"read\00" -@fld.str.615 = private constant [6 x i8] c"write\00" -@fld.str.616 = private constant [7 x i8] c"append\00" -@fld.str.617 = private constant [11 x i8] c"read_write\00" -@field_names.618 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.614, i64 4 }, { ptr, i64 } { ptr @fld.str.615, i64 5 }, { ptr, i64 } { ptr @fld.str.616, i64 6 }, { ptr, i64 } { ptr @fld.str.617, i64 10 }] -@str.619 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.620 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.621 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.622 = private constant [4 x i8] c"set\00" -@fld.str.623 = private constant [8 x i8] c"current\00" -@fld.str.624 = private constant [4 x i8] c"end\00" -@field_names.625 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.622, i64 3 }, { ptr, i64 } { ptr @fld.str.623, i64 7 }, { ptr, i64 } { ptr @fld.str.624, i64 3 }] -@str.626 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.627 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.628 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.629 = private constant [6 x i8] c"null_\00" -@fld.str.630 = private constant [6 x i8] c"bool_\00" -@fld.str.631 = private constant [5 x i8] c"int_\00" -@fld.str.632 = private constant [4 x i8] c"str\00" -@fld.str.633 = private constant [6 x i8] c"array\00" -@fld.str.634 = private constant [7 x i8] c"object\00" -@field_names.635 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.629, i64 5 }, { ptr, i64 } { ptr @fld.str.630, i64 5 }, { ptr, i64 } { ptr @fld.str.631, i64 4 }, { ptr, i64 } { ptr @fld.str.632, i64 3 }, { ptr, i64 } { ptr @fld.str.633, i64 5 }, { ptr, i64 } { ptr @fld.str.634, i64 6 }] -@str.636 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.637 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.638 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.639 = private constant [6 x i8] c"macos\00" -@fld.str.640 = private constant [6 x i8] c"linux\00" -@fld.str.641 = private constant [8 x i8] c"windows\00" -@fld.str.642 = private constant [5 x i8] c"wasm\00" -@fld.str.643 = private constant [4 x i8] c"ios\00" -@fld.str.644 = private constant [8 x i8] c"android\00" -@fld.str.645 = private constant [8 x i8] c"unknown\00" -@field_names.646 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.639, i64 5 }, { ptr, i64 } { ptr @fld.str.640, i64 5 }, { ptr, i64 } { ptr @fld.str.641, i64 7 }, { ptr, i64 } { ptr @fld.str.642, i64 4 }, { ptr, i64 } { ptr @fld.str.643, i64 3 }, { ptr, i64 } { ptr @fld.str.644, i64 7 }, { ptr, i64 } { ptr @fld.str.645, i64 7 }] -@str.647 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.648 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.649 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.650 = private constant [8 x i8] c"aarch64\00" -@fld.str.651 = private constant [7 x i8] c"x86_64\00" -@fld.str.652 = private constant [7 x i8] c"wasm32\00" -@fld.str.653 = private constant [7 x i8] c"wasm64\00" -@fld.str.654 = private constant [8 x i8] c"unknown\00" -@field_names.655 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.650, i64 7 }, { ptr, i64 } { ptr @fld.str.651, i64 6 }, { ptr, i64 } { ptr @fld.str.652, i64 6 }, { ptr, i64 } { ptr @fld.str.653, i64 6 }, { ptr, i64 } { ptr @fld.str.654, i64 7 }] -@str.656 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.657 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.658 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.659 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.660 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.661 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.662 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.663 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.664 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.665 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.666 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.667 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.668 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.669 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.670 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.671 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.672 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.673 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.674 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.675 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.676 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.677 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.678 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.679 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.680 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.681 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.682 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.683 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.684 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.685 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.686 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.687 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.688 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.689 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.690 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.691 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.692 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.693 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.694 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.695 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.696 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.697 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.698 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.699 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.700 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.701 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.702 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.703 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.704 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 -@str.705 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.706 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.707 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 -@str.708 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.709 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.710 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 -@str.711 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.712 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.713 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 -@str.714 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.715 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.716 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 -@str.717 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.718 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.719 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 -@str.720 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.721 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.722 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 -@str.723 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.724 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.725 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 -@str.726 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.727 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.728 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 -@str.729 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.730 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.731 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 -@str.732 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.733 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.734 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 -@str.735 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.736 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.737 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 -@str.738 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.739 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.740 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 -@str.741 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.742 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.743 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 -@str.744 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.745 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.746 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 -@str.747 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.748 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.749 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 -@str.750 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.751 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.752 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 -@str.753 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.754 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.755 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 -@str.756 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.757 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.758 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 -@str.759 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.760 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.761 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 -@str.762 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.763 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.764 = private unnamed_addr constant [10 x i8] c"*NSString\00", align 1 -@str.765 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.766 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.767 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 -@str.768 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.769 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.770 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 -@str.771 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.772 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.773 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 -@str.774 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.775 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.776 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 -@str.777 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.778 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.779 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 -@str.780 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.781 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.782 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 -@str.783 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.784 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.785 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 -@str.786 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.787 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.788 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1 -@str.789 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.790 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.791 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 -@str.792 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.793 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.794 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@fld.str.386 = private constant [5 x i8] c"line\00" +@fld.str.387 = private constant [4 x i8] c"col\00" +@fld.str.388 = private constant [5 x i8] c"func\00" +@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.386, i64 4 }, { ptr, i64 } { ptr @fld.str.387, i64 3 }, { ptr, i64 } { ptr @fld.str.388, i64 4 }] +@str.389 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.390 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.391 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.392 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.393 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.394 = private constant [4 x i8] c"ctx\00" +@fld.str.395 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.396 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.397 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.394, i64 3 }, { ptr, i64 } { ptr @fld.str.395, i64 11 }, { ptr, i64 } { ptr @fld.str.396, i64 13 }] +@str.398 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.399 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.400 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.401 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.402 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.403 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.404 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.405 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.406 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.407 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.408 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.409 = private constant [12 x i8] c"alloc_count\00" +@field_names.410 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.409, i64 11 }] +@str.411 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.412 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.413 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.414 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.415 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.416 = private constant [5 x i8] c"next\00" +@fld.str.417 = private constant [4 x i8] c"cap\00" +@field_names.418 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.416, i64 4 }, { ptr, i64 } { ptr @fld.str.417, i64 3 }] +@str.419 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.420 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.421 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.422 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.423 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.424 = private constant [6 x i8] c"first\00" +@fld.str.425 = private constant [10 x i8] c"end_index\00" +@fld.str.426 = private constant [7 x i8] c"parent\00" +@field_names.427 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.424, i64 5 }, { ptr, i64 } { ptr @fld.str.425, i64 9 }, { ptr, i64 } { ptr @fld.str.426, i64 6 }] +@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.429 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.430 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.431 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.432 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.433 = private constant [4 x i8] c"buf\00" +@fld.str.434 = private constant [4 x i8] c"len\00" +@fld.str.435 = private constant [4 x i8] c"pos\00" +@field_names.436 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 3 }, { ptr, i64 } { ptr @fld.str.434, i64 3 }, { ptr, i64 } { ptr @fld.str.435, i64 3 }] +@str.437 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.438 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.439 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.440 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.441 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.442 = private constant [7 x i8] c"parent\00" +@fld.str.443 = private constant [12 x i8] c"alloc_count\00" +@fld.str.444 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.445 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.446 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 6 }, { ptr, i64 } { ptr @fld.str.443, i64 11 }, { ptr, i64 } { ptr @fld.str.444, i64 13 }, { ptr, i64 } { ptr @fld.str.445, i64 17 }] +@str.447 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.448 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.449 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.450 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.451 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.452 = private constant [10 x i8] c"allocator\00" +@fld.str.453 = private constant [5 x i8] c"data\00" +@field_names.454 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.452, i64 9 }, { ptr, i64 } { ptr @fld.str.453, i64 4 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.457 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.458 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.459 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.460 = private constant [3 x i8] c"fd\00" +@field_names.461 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 2 }] +@str.462 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.463 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.464 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.465 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.466 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.467 = private constant [5 x i8] c"file\00" +@fld.str.468 = private constant [5 x i8] c"line\00" +@fld.str.469 = private constant [4 x i8] c"col\00" +@fld.str.470 = private constant [5 x i8] c"func\00" +@fld.str.471 = private constant [10 x i8] c"line_text\00" +@field_names.472 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.467, i64 4 }, { ptr, i64 } { ptr @fld.str.468, i64 4 }, { ptr, i64 } { ptr @fld.str.469, i64 3 }, { ptr, i64 } { ptr @fld.str.470, i64 4 }, { ptr, i64 } { ptr @fld.str.471, i64 9 }] +@str.473 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.474 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.475 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.476 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.477 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.478 = private constant [10 x i8] c"exit_code\00" +@fld.str.479 = private constant [7 x i8] c"stdout\00" +@field_names.480 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.478, i64 9 }, { ptr, i64 } { ptr @fld.str.479, i64 6 }] +@str.481 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.482 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.483 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.484 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.485 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.486 = private constant [8 x i8] c"sin_len\00" +@fld.str.487 = private constant [11 x i8] c"sin_family\00" +@fld.str.488 = private constant [9 x i8] c"sin_port\00" +@fld.str.489 = private constant [9 x i8] c"sin_addr\00" +@fld.str.490 = private constant [9 x i8] c"sin_zero\00" +@field_names.491 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.486, i64 7 }, { ptr, i64 } { ptr @fld.str.487, i64 10 }, { ptr, i64 } { ptr @fld.str.488, i64 8 }, { ptr, i64 } { ptr @fld.str.489, i64 8 }, { ptr, i64 } { ptr @fld.str.490, i64 8 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [6 x i8] c"Array\00", align 1 +@str.494 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.496 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.497 = private constant [6 x i8] c"items\00" +@fld.str.498 = private constant [4 x i8] c"len\00" +@fld.str.499 = private constant [4 x i8] c"cap\00" +@field_names.500 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.497, i64 5 }, { ptr, i64 } { ptr @fld.str.498, i64 3 }, { ptr, i64 } { ptr @fld.str.499, i64 3 }] +@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.502 = private unnamed_addr constant [7 x i8] c"Object\00", align 1 +@str.503 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.504 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.505 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.506 = private constant [6 x i8] c"items\00" +@fld.str.507 = private constant [4 x i8] c"len\00" +@fld.str.508 = private constant [4 x i8] c"cap\00" +@field_names.509 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.506, i64 5 }, { ptr, i64 } { ptr @fld.str.507, i64 3 }, { ptr, i64 } { ptr @fld.str.508, i64 3 }] +@str.510 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.511 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.512 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.513 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.514 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.515 = private constant [4 x i8] c"key\00" +@fld.str.516 = private constant [4 x i8] c"val\00" +@field_names.517 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.515, i64 3 }, { ptr, i64 } { ptr @fld.str.516, i64 3 }] +@str.518 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.519 = private unnamed_addr constant [5 x i8] c"Sink\00", align 1 +@str.520 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.521 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.522 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.523 = private constant [4 x i8] c"dst\00" +@fld.str.524 = private constant [4 x i8] c"pos\00" +@fld.str.525 = private constant [5 x i8] c"file\00" +@field_names.526 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.523, i64 3 }, { ptr, i64 } { ptr @fld.str.524, i64 3 }, { ptr, i64 } { ptr @fld.str.525, i64 4 }] +@str.527 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.528 = private unnamed_addr constant [7 x i8] c"Parser\00", align 1 +@str.529 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.530 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.531 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.532 = private constant [4 x i8] c"src\00" +@fld.str.533 = private constant [4 x i8] c"pos\00" +@fld.str.534 = private constant [6 x i8] c"alloc\00" +@field_names.535 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.532, i64 3 }, { ptr, i64 } { ptr @fld.str.533, i64 3 }, { ptr, i64 } { ptr @fld.str.534, i64 5 }] +@str.536 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.537 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.538 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.539 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.540 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.541 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.542 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.543 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.544 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.545 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.546 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.547 = private constant [5 x i8] c"name\00" +@fld.str.548 = private constant [12 x i8] c"takes_value\00" +@fld.str.549 = private constant [9 x i8] c"required\00" +@field_names.550 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.547, i64 4 }, { ptr, i64 } { ptr @fld.str.548, i64 11 }, { ptr, i64 } { ptr @fld.str.549, i64 8 }] +@str.551 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.552 = private unnamed_addr constant [8 x i8] c"Command\00", align 1 +@str.553 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.554 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.555 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.556 = private constant [6 x i8] c"group\00" +@fld.str.557 = private constant [8 x i8] c"command\00" +@fld.str.558 = private constant [6 x i8] c"flags\00" +@field_names.559 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.556, i64 5 }, { ptr, i64 } { ptr @fld.str.557, i64 7 }, { ptr, i64 } { ptr @fld.str.558, i64 5 }] +@str.560 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.561 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.562 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.563 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.564 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.565 = private constant [4 x i8] c"set\00" +@fld.str.566 = private constant [6 x i8] c"value\00" +@field_names.567 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.565, i64 3 }, { ptr, i64 } { ptr @fld.str.566, i64 5 }] +@str.568 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.569 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.570 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.571 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.572 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.573 = private constant [6 x i8] c"index\00" +@fld.str.574 = private constant [6 x i8] c"token\00" +@field_names.575 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.573, i64 5 }, { ptr, i64 } { ptr @fld.str.574, i64 5 }] +@str.576 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.577 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.578 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.579 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.580 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.581 = private constant [6 x i8] c"group\00" +@fld.str.582 = private constant [8 x i8] c"command\00" +@fld.str.583 = private constant [10 x i8] c"cmd_index\00" +@fld.str.584 = private constant [5 x i8] c"json\00" +@fld.str.585 = private constant [5 x i8] c"rest\00" +@fld.str.586 = private constant [5 x i8] c"spec\00" +@fld.str.587 = private constant [7 x i8] c"values\00" +@field_names.588 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.581, i64 5 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 9 }, { ptr, i64 } { ptr @fld.str.584, i64 4 }, { ptr, i64 } { ptr @fld.str.585, i64 4 }, { ptr, i64 } { ptr @fld.str.586, i64 4 }, { ptr, i64 } { ptr @fld.str.587, i64 6 }] +@str.589 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.590 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.591 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.592 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.593 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.594 = private constant [2 x i8] c"h\00" +@fld.str.595 = private constant [4 x i8] c"buf\00" +@fld.str.596 = private constant [8 x i8] c"buf_len\00" +@fld.str.597 = private constant [10 x i8] c"total_len\00" +@field_names.598 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.594, i64 1 }, { ptr, i64 } { ptr @fld.str.595, i64 3 }, { ptr, i64 } { ptr @fld.str.596, i64 7 }, { ptr, i64 } { ptr @fld.str.597, i64 9 }] +@str.599 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.600 = private unnamed_addr constant [9 x i8] c"NSString\00", align 1 +@str.601 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.602 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.603 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.604 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.605 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.606 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1 +@str.607 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.608 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.609 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.610 = private constant [2 x i8] c"a\00" +@fld.str.611 = private constant [2 x i8] c"b\00" +@fld.str.612 = private constant [2 x i8] c"c\00" +@field_names.613 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.610, i64 1 }, { ptr, i64 } { ptr @fld.str.611, i64 1 }, { ptr, i64 } { ptr @fld.str.612, i64 1 }] +@str.614 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.615 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.616 = private constant [5 x i8] c"read\00" +@fld.str.617 = private constant [6 x i8] c"write\00" +@fld.str.618 = private constant [7 x i8] c"append\00" +@fld.str.619 = private constant [11 x i8] c"read_write\00" +@field_names.620 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.616, i64 4 }, { ptr, i64 } { ptr @fld.str.617, i64 5 }, { ptr, i64 } { ptr @fld.str.618, i64 6 }, { ptr, i64 } { ptr @fld.str.619, i64 10 }] +@str.621 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.622 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.623 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.624 = private constant [4 x i8] c"set\00" +@fld.str.625 = private constant [8 x i8] c"current\00" +@fld.str.626 = private constant [4 x i8] c"end\00" +@field_names.627 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.624, i64 3 }, { ptr, i64 } { ptr @fld.str.625, i64 7 }, { ptr, i64 } { ptr @fld.str.626, i64 3 }] +@str.628 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.629 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.630 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.631 = private constant [6 x i8] c"null_\00" +@fld.str.632 = private constant [6 x i8] c"bool_\00" +@fld.str.633 = private constant [5 x i8] c"int_\00" +@fld.str.634 = private constant [4 x i8] c"str\00" +@fld.str.635 = private constant [6 x i8] c"array\00" +@fld.str.636 = private constant [7 x i8] c"object\00" +@field_names.637 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.631, i64 5 }, { ptr, i64 } { ptr @fld.str.632, i64 5 }, { ptr, i64 } { ptr @fld.str.633, i64 4 }, { ptr, i64 } { ptr @fld.str.634, i64 3 }, { ptr, i64 } { ptr @fld.str.635, i64 5 }, { ptr, i64 } { ptr @fld.str.636, i64 6 }] +@str.638 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.639 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.640 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.641 = private constant [6 x i8] c"macos\00" +@fld.str.642 = private constant [6 x i8] c"linux\00" +@fld.str.643 = private constant [8 x i8] c"windows\00" +@fld.str.644 = private constant [5 x i8] c"wasm\00" +@fld.str.645 = private constant [4 x i8] c"ios\00" +@fld.str.646 = private constant [8 x i8] c"android\00" +@fld.str.647 = private constant [8 x i8] c"unknown\00" +@field_names.648 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.641, i64 5 }, { ptr, i64 } { ptr @fld.str.642, i64 5 }, { ptr, i64 } { ptr @fld.str.643, i64 7 }, { ptr, i64 } { ptr @fld.str.644, i64 4 }, { ptr, i64 } { ptr @fld.str.645, i64 3 }, { ptr, i64 } { ptr @fld.str.646, i64 7 }, { ptr, i64 } { ptr @fld.str.647, i64 7 }] +@str.649 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.650 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.651 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.652 = private constant [8 x i8] c"aarch64\00" +@fld.str.653 = private constant [7 x i8] c"x86_64\00" +@fld.str.654 = private constant [7 x i8] c"wasm32\00" +@fld.str.655 = private constant [7 x i8] c"wasm64\00" +@fld.str.656 = private constant [8 x i8] c"unknown\00" +@field_names.657 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.652, i64 7 }, { ptr, i64 } { ptr @fld.str.653, i64 6 }, { ptr, i64 } { ptr @fld.str.654, i64 6 }, { ptr, i64 } { ptr @fld.str.655, i64 6 }, { ptr, i64 } { ptr @fld.str.656, i64 7 }] +@str.658 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.659 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.660 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.661 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.662 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.663 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.664 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.665 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.666 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.667 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.668 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.669 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.670 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.671 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.672 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.673 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.674 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.675 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.676 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.677 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.678 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.679 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.680 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.681 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.682 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.683 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.684 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.685 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.686 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.687 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.688 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.689 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.690 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.691 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.692 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.693 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.694 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.695 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.696 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.697 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 +@str.698 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.700 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 +@str.701 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 +@str.704 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.705 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.706 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.707 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.708 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.709 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.710 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.711 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.712 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.713 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.714 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.715 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.716 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.717 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.718 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.719 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.720 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.721 = private unnamed_addr constant [6 x i8] c"*File\00", align 1 +@str.722 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.723 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.724 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.725 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.726 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.727 = private unnamed_addr constant [5 x i8] c"*s32\00", align 1 +@str.728 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.729 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.730 = private unnamed_addr constant [10 x i8] c"*SockAddr\00", align 1 +@str.731 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.732 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.733 = private unnamed_addr constant [5 x i8] c"*u32\00", align 1 +@str.734 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.735 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.736 = private unnamed_addr constant [9 x i8] c"[*]Value\00", align 1 +@str.737 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.738 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.739 = private unnamed_addr constant [7 x i8] c"*Array\00", align 1 +@str.740 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.741 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.742 = private unnamed_addr constant [10 x i8] c"[*]Member\00", align 1 +@str.743 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.744 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.745 = private unnamed_addr constant [8 x i8] c"*Object\00", align 1 +@str.746 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.748 = private unnamed_addr constant [6 x i8] c"*Sink\00", align 1 +@str.749 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.750 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.751 = private unnamed_addr constant [8 x i8] c"*Parser\00", align 1 +@str.752 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.753 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.754 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.755 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.756 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.757 = private unnamed_addr constant [8 x i8] c"*Parsed\00", align 1 +@str.758 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.759 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.760 = private unnamed_addr constant [6 x i8] c"*Diag\00", align 1 +@str.761 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.762 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.763 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.764 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.765 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.766 = private unnamed_addr constant [10 x i8] c"*NSString\00", align 1 +@str.767 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.768 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.769 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.770 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.771 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.772 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.773 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.774 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.775 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.776 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.777 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.778 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.779 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.780 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.781 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.782 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.783 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.784 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.785 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.786 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.787 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.788 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.789 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.790 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1 +@str.791 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.792 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.793 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.794 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.795 = private unnamed_addr constant [5 x i8] c"null\00", align 1 @str.796 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.797 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.798 = private unnamed_addr constant [5 x i8] c"null\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 }] @@ -658,6 +658,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -877,7 +880,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.162, i64 1 } + ret { ptr, i64 } { ptr @str.164, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1004,7 +1007,7 @@ if.else.79: ; preds = %entry br label %if.merge.80 if.merge.80: ; preds = %if.else.79, %if.then.78 - %bp = phi { ptr, i64 } [ { ptr @str.163, i64 4 }, %if.then.78 ], [ { ptr @str.164, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.165, i64 4 }, %if.then.78 ], [ { ptr @str.166, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1338,7 +1341,7 @@ entry: br i1 %icmp, label %if.then.389, label %if.merge.390 if.then.389: ; preds = %entry - ret { ptr, i64 } { ptr @str.165, i64 1 } + ret { ptr, i64 } { ptr @str.167, i64 1 } if.merge.390: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1488,7 +1491,7 @@ entry: %allocaN = alloca { ptr, i64 }, align 8 store { i64, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.166, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.168, i64 3 }, ptr %allocaN, align 8 %load = load { i64, i64 }, ptr %alloca, align 8 %sg = extractvalue { i64, i64 } %load, 0 %ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1 @@ -1514,9 +1517,9 @@ entry: i64 11, label %match.arm.42 i64 19, label %match.arm.43 i64 20, label %match.arm.43 - i64 22, label %match.arm.43 - i64 24, label %match.arm.43 - i64 26, label %match.arm.43 + i64 21, label %match.arm.43 + i64 23, label %match.arm.43 + i64 25, label %match.arm.43 i64 27, label %match.arm.43 i64 30, label %match.arm.43 i64 32, label %match.arm.43 @@ -1560,9 +1563,9 @@ entry: i64 85, label %match.arm.48 i64 101, label %match.arm.48 i64 18, label %match.arm.49 - i64 21, label %match.arm.49 - i64 23, label %match.arm.49 - i64 25, label %match.arm.49 + i64 22, label %match.arm.49 + i64 24, label %match.arm.49 + i64 26, label %match.arm.49 i64 28, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 @@ -1604,7 +1607,7 @@ match.merge.37: ; preds = %dispatch.merge.498, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.167, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.169, i64 0 }, ptr %allocaN, align 8 br label %match.merge.37 match.arm.39: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry @@ -1648,9 +1651,9 @@ match.arm.43: ; preds = %entry, %entry, %ent switch i64 %ua.raw16, label %dispatch.default.95 [ i64 19, label %dispatch.case.96 i64 20, label %dispatch.case.97 - i64 22, label %dispatch.case.98 - i64 24, label %dispatch.case.99 - i64 26, label %dispatch.case.100 + i64 21, label %dispatch.case.98 + i64 23, label %dispatch.case.99 + i64 25, label %dispatch.case.100 i64 27, label %dispatch.case.101 i64 30, label %dispatch.case.102 i64 32, label %dispatch.case.103 @@ -1734,9 +1737,9 @@ match.arm.49: ; preds = %entry, %entry, %ent %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.352 [ i64 18, label %dispatch.case.353 - i64 21, label %dispatch.case.354 - i64 23, label %dispatch.case.355 - i64 25, label %dispatch.case.356 + i64 22, label %dispatch.case.354 + i64 24, label %dispatch.case.355 + i64 26, label %dispatch.case.356 i64 28, label %dispatch.case.357 i64 29, label %dispatch.case.358 i64 31, label %dispatch.case.359 @@ -1836,7 +1839,7 @@ dispatch.merge.94: ; preds = %dispatch.case.122, br label %match.merge.37 dispatch.default.95: ; preds = %match.arm.43 - store { ptr, i64 } { ptr @str.349, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.351, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1850,32 +1853,32 @@ dispatch.case.96: ; preds = %match.arm.43 dispatch.case.97: ; preds = %match.arm.43 %ua.raw64 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr65 = inttoptr i64 %ua.raw64 to ptr - %ua.load66 = load {}, ptr %ua.ptr65, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load66) + %ua.load66 = load { ptr, ptr, ptr }, ptr %ua.ptr65, align 8 + %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load66) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.98: ; preds = %match.arm.43 %ua.raw68 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr69 = inttoptr i64 %ua.raw68 to ptr - %ua.load70 = load { i64 }, ptr %ua.ptr69, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load70) + %ua.load70 = load {}, ptr %ua.ptr69, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.99: ; preds = %match.arm.43 %ua.raw72 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr73 = inttoptr i64 %ua.raw72 to ptr - %ua.load74 = load { ptr, i64 }, ptr %ua.ptr73, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load74) + %ua.load74 = load { i64 }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load74) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.100: ; preds = %match.arm.43 %ua.raw76 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr77 = inttoptr i64 %ua.raw76 to ptr - %ua.load78 = load { ptr, ptr, ptr }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load78) + %ua.load78 = load { ptr, i64 }, ptr %ua.ptr77, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load78) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2061,7 +2064,7 @@ dispatch.merge.258: ; preds = %dispatch.case.264, br label %match.merge.37 dispatch.default.259: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.350, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.352, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.258 dispatch.case.260: ; preds = %match.arm.44 @@ -2102,7 +2105,7 @@ dispatch.merge.275: ; preds = %dispatch.case.283, br label %match.merge.37 dispatch.default.276: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.351, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.353, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.275 dispatch.case.277: ; preds = %match.arm.47 @@ -2167,7 +2170,7 @@ dispatch.merge.319: ; preds = %dispatch.case.325, br label %match.merge.37 dispatch.default.320: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.352, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.354, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.319 dispatch.case.321: ; preds = %match.arm.48 @@ -2216,7 +2219,7 @@ dispatch.merge.351: ; preds = %dispatch.case.385, br label %match.merge.37 dispatch.default.352: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.353, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.355, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.351 dispatch.case.353: ; preds = %match.arm.49 @@ -2456,7 +2459,7 @@ dispatch.merge.498: ; preds = %dispatch.case.503, br label %match.merge.37 dispatch.default.499: ; preds = %match.arm.50 - store { ptr, i64 } { ptr @str.354, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.356, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.498 dispatch.case.500: ; preds = %match.arm.50 @@ -2498,7 +2501,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.355, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.357, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2594,7 +2597,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2602,7 +2605,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2612,13 +2615,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2626,7 +2629,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2640,7 +2643,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.361, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2648,7 +2651,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2659,7 +2662,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2716,7 +2719,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2724,7 +2727,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2735,7 +2738,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2755,7 +2758,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2763,7 +2766,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, 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 @@ -2774,7 +2777,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2784,64 +2787,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3017,163 +3023,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3371,64 +3380,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3458,97 +3467,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3587,118 +3596,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -3766,19 +3775,19 @@ entry: define i32 @main() #0 { entry: call void @__sx_objc_selector_init() - %call = call ptr @objc_getClass(ptr @str.370) + %call = call ptr @objc_getClass(ptr @str.372) %alloca = alloca ptr, align 8 store ptr %call, ptr %alloca, align 8 %load = load ptr, ptr %alloca, align 8 - %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.371, i64 0) + %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.373, i64 0) %allocaN = alloca ptr, align 8 store ptr %callN, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.372) + %callN = call ptr @sel_registerName(ptr @str.374) %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.373) + %callN = call i1 @class_addMethod(ptr %loadN, ptr %loadN, ptr @triple_imp, ptr @str.375) %allocaN = alloca i1, align 1 store i1 %callN, ptr %allocaN, align 1 %loadN = load i1, ptr %allocaN, align 1 @@ -3824,7 +3833,7 @@ entry: define internal void @print__ct_s7f3aff1506f207ab__pack_bool(ptr %0, i1 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.374, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.376, i64 15 }, ptr %alloca, align 8 %allocaN = alloca i1, align 1 store i1 %1, ptr %allocaN, align 1 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -3840,7 +3849,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.375, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.377, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -3868,7 +3877,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.376, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.378, i64 15 }) ret { ptr, i64 } %call } @@ -3876,7 +3885,7 @@ entry: define internal void @print__ct_s337be2777a405332__pack_s64_s64_s64(ptr %0, i64 %1, i64 %2, i64 %3) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.377, i64 22 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.379, i64 22 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3903,7 +3912,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 3, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.378, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.380, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 10) @@ -3952,7 +3961,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.379, i64 22 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.381, i64 22 }) ret { ptr, i64 } %call } @@ -3963,7 +3972,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp26 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.380, i64 15 }, { ptr, i64 } { ptr @str.381, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.382, i64 15 }, { ptr, i64 } { ptr @str.383, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3982,12 +3991,12 @@ while.body.124: ; preds = %while.hdr.123 while.exit.125: ; preds = %while.hdr.123 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.384, i64 1 }) ret { ptr, i64 } %callN if.then.126: ; preds = %while.body.124 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.383, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.385, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.127 @@ -3999,7 +4008,7 @@ if.merge.127: ; preds = %if.then.126, %while %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.389, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4052,20 +4061,20 @@ fv.case24: ; preds = %if.merge.127 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { entry: - %alloca = alloca {}, align 8 - store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 10 }, { ptr, i64 } { ptr @str.389, i64 1 }) + %alloca = alloca { ptr, ptr, ptr }, align 8 + store { ptr, ptr, ptr } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 9 }, { ptr, i64 } { ptr @str.391, 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.128 -while.hdr.128: ; preds = %if.merge.132, %entry +while.hdr.128: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.129, label %while.exit.130 while.body.129: ; preds = %while.hdr.128 @@ -4075,224 +4084,24 @@ while.body.129: ; preds = %while.hdr.128 while.exit.130: ; preds = %while.hdr.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.390, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.392, i64 1 }) ret { ptr, i64 } %callN if.then.131: ; preds = %while.body.129 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.391, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.132 if.merge.132: ; preds = %if.then.131, %while.body.129 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.392, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.397, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.393, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load {}, ptr %alloca, align 1 - %loadN = load i64, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.128 -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { -entry: - %alloca = alloca { i64 }, align 8 - store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 3 }, { ptr, i64 } { ptr @str.395, 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.133 - -while.hdr.133: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.134, label %while.exit.135 - -while.body.134: ; preds = %while.hdr.133 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.136, label %if.merge.137 - -while.exit.135: ; preds = %while.hdr.133 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.396, i64 1 }) - ret { ptr, i64 } %callN - -if.then.136: ; preds = %while.body.134 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.137 - -if.merge.137: ; preds = %if.then.136, %while.body.134 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.399, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.400, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - ] - -fv.merge: ; preds = %fv.default, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.133 - -fv.default: ; preds = %if.merge.137 - br label %fv.merge - -fv.case: ; preds = %if.merge.137 - %fv.field = extractvalue { i64 } %loadN, 0 - %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.401, i64 10 }, { ptr, i64 } { ptr @str.402, 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.138 - -while.hdr.138: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.139, label %while.exit.140 - -while.body.139: ; preds = %while.hdr.138 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.141, label %if.merge.142 - -while.exit.140: ; preds = %while.hdr.138 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.403, i64 1 }) - ret { ptr, i64 } %callN - -if.then.141: ; preds = %while.body.139 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.142 - -if.merge.142: ; preds = %if.then.141, %while.body.139 - %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.407, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - ] - -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.138 - -fv.default: ; preds = %if.merge.142 - br label %fv.merge - -fv.case: ; preds = %if.merge.142 - %fv.field = extractvalue { ptr, i64 } %loadN, 0 - %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.142 - %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__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 { -entry: - %alloca = alloca { ptr, ptr, ptr }, align 8 - store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.409, i64 9 }, { ptr, i64 } { ptr @str.410, 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.143 - -while.hdr.143: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.144, label %while.exit.145 - -while.body.144: ; preds = %while.hdr.143 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.146, label %if.merge.147 - -while.exit.145: ; preds = %while.hdr.143 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 1 }) - ret { ptr, i64 } %callN - -if.then.146: ; preds = %while.body.144 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.412, i64 2 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.147 - -if.merge.147: ; preds = %if.then.146, %while.body.144 - %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.416, i64 0, i64 %loadN - %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.398, 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 @@ -4311,27 +4120,227 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.128 + +fv.default: ; preds = %if.merge.132 + br label %fv.merge + +fv.case: ; preds = %if.merge.132 + %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.132 + %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 + %pNi19 = ptrtoint ptr %fv.field18 to i64 + %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 + br label %fv.merge + +fv.case21: ; preds = %if.merge.132 + %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 + %pNi23 = ptrtoint ptr %fv.field22 to i64 + %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 10 }, { ptr, i64 } { ptr @str.400, 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.133 + +while.hdr.133: ; preds = %if.merge.137, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.134, label %while.exit.135 + +while.body.134: ; preds = %while.hdr.133 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.136, label %if.merge.137 + +while.exit.135: ; preds = %while.hdr.133 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.401, i64 1 }) + ret { ptr, i64 } %callN + +if.then.136: ; preds = %while.body.134 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.402, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.137 + +if.merge.137: ; preds = %if.then.136, %while.body.134 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.403, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.404, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.133 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { +entry: + %alloca = alloca { i64 }, align 8 + store { i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.405, i64 3 }, { ptr, i64 } { ptr @str.406, 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.138 + +while.hdr.138: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 1 + br i1 %icmp, label %while.body.139, label %while.exit.140 + +while.body.139: ; preds = %while.hdr.138 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.141, label %if.merge.142 + +while.exit.140: ; preds = %while.hdr.138 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.407, i64 1 }) + ret { ptr, i64 } %callN + +if.then.141: ; preds = %while.body.139 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.408, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.142 + +if.merge.142: ; preds = %if.then.141, %while.body.139 + %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.410, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.411, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + ] + +fv.merge: ; preds = %fv.default, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.138 + +fv.default: ; preds = %if.merge.142 + br label %fv.merge + +fv.case: ; preds = %if.merge.142 + %fv.field = extractvalue { i64 } %loadN, 0 + %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.412, i64 10 }, { ptr, i64 } { ptr @str.413, 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.143 + +while.hdr.143: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 2 + br i1 %icmp, label %while.body.144, label %while.exit.145 + +while.body.144: ; preds = %while.hdr.143 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.146, label %if.merge.147 + +while.exit.145: ; preds = %while.hdr.143 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.414, i64 1 }) + ret { ptr, i64 } %callN + +if.then.146: ; preds = %while.body.144 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.415, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.147 + +if.merge.147: ; preds = %if.then.146, %while.body.144 + %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.418, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.419, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 br label %while.hdr.143 fv.default: ; preds = %if.merge.147 br label %fv.merge fv.case: ; preds = %if.merge.147 - %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 + %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.147 - %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 - %pNi19 = ptrtoint ptr %fv.field18 to i64 - %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 - br label %fv.merge - -fv.case21: ; preds = %if.merge.147 - %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 - %pNi23 = ptrtoint ptr %fv.field22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 + %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge } @@ -4341,7 +4350,7 @@ entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.418, i64 5 }, { ptr, i64 } { ptr @str.419, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.420, i64 5 }, { ptr, i64 } { ptr @str.421, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4360,24 +4369,24 @@ while.body.149: ; preds = %while.hdr.148 while.exit.150: ; preds = %while.hdr.148 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.420, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.422, i64 1 }) ret { ptr, i64 } %callN if.then.151: ; preds = %while.body.149 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.421, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.423, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.152 if.merge.152: ; preds = %if.then.151, %while.body.149 %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.425, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.427, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.426, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.428, 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 @@ -4404,7 +4413,7 @@ fv.default: ; preds = %if.merge.152 fv.case: ; preds = %if.merge.152 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 - %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.152 @@ -4416,7 +4425,7 @@ fv.case20: ; preds = %if.merge.152 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } @@ -4425,7 +4434,7 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.427, i64 8 }, { ptr, i64 } { ptr @str.428, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 8 }, { ptr, i64 } { ptr @str.430, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4444,24 +4453,24 @@ while.body.154: ; preds = %while.hdr.153 while.exit.155: ; preds = %while.hdr.153 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.429, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.431, i64 1 }) ret { ptr, i64 } %callN if.then.156: ; preds = %while.body.154 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.430, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.432, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.157 if.merge.157: ; preds = %if.then.156, %while.body.154 %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.434, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.436, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.435, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.437, 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 @@ -4508,7 +4517,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 17 }, { ptr, i64 } { ptr @str.437, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 17 }, { ptr, i64 } { ptr @str.439, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4527,24 +4536,24 @@ while.body.159: ; preds = %while.hdr.158 while.exit.160: ; preds = %while.hdr.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.438, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.440, i64 1 }) ret { ptr, i64 } %callN if.then.161: ; preds = %while.body.159 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.439, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.441, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.162 if.merge.162: ; preds = %if.then.161, %while.body.159 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.444, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.446, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.445, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.447, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -4573,7 +4582,7 @@ fv.case: ; preds = %if.merge.162 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.162 @@ -4598,7 +4607,7 @@ entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.446, i64 7 }, { ptr, i64 } { ptr @str.447, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.448, i64 7 }, { ptr, i64 } { ptr @str.449, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4617,24 +4626,24 @@ while.body.164: ; preds = %while.hdr.163 while.exit.165: ; preds = %while.hdr.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.448, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.450, i64 1 }) ret { ptr, i64 } %callN if.then.166: ; preds = %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.449, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.451, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.167 if.merge.167: ; preds = %if.then.166, %while.body.164 %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.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.453, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.455, 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 @@ -4661,7 +4670,7 @@ fv.case: ; preds = %if.merge.167 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 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 26, i64 undef }, i64 %ba.p2i, 1 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.167 @@ -4676,7 +4685,7 @@ define internal { ptr, i64 } @struct_to_string__File(ptr %0, { i32 } %1) #0 { entry: %alloca = alloca { i32 }, align 8 store { i32 } %1, ptr %alloca, align 4 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 4 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 4 }, { ptr, i64 } { ptr @str.457, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4695,24 +4704,24 @@ while.body.169: ; preds = %while.hdr.168 while.exit.170: ; preds = %while.hdr.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, i64 1 }) ret { ptr, i64 } %callN if.then.171: ; preds = %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.459, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.172 if.merge.172: ; preds = %if.then.171, %while.body.169 %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.459, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.461, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.460, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.462, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4749,7 +4758,7 @@ entry: %ba.tmp26 = alloca { ptr, i64 }, align 8 %ba.tmp31 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.461, i64 10 }, { ptr, i64 } { ptr @str.462, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.463, i64 10 }, { ptr, i64 } { ptr @str.464, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4768,24 +4777,24 @@ while.body.174: ; preds = %while.hdr.173 while.exit.175: ; preds = %while.hdr.173 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.463, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.465, i64 1 }) ret { ptr, i64 } %callN if.then.176: ; preds = %while.body.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.464, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.466, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.177 if.merge.177: ; preds = %if.then.176, %while.body.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.470, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.472, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.471, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.473, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4851,7 +4860,7 @@ entry: %alloca = alloca { i32, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i32, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.472, i64 13 }, { ptr, i64 } { ptr @str.473, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.474, i64 13 }, { ptr, i64 } { ptr @str.475, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4870,24 +4879,24 @@ while.body.179: ; preds = %while.hdr.178 while.exit.180: ; preds = %while.hdr.178 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.474, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.476, i64 1 }) ret { ptr, i64 } %callN if.then.181: ; preds = %while.body.179 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.475, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.477, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.182 if.merge.182: ; preds = %if.then.181, %while.body.179 %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.478, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.480, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.479, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4929,7 +4938,7 @@ define internal { ptr, i64 } @struct_to_string__SockAddr(ptr %0, { i8, i8, i16, entry: %alloca = alloca { i8, i8, i16, i32, i64 }, align 8 store { i8, i8, i16, i32, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.480, i64 8 }, { ptr, i64 } { ptr @str.481, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.482, i64 8 }, { ptr, i64 } { ptr @str.483, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4948,24 +4957,24 @@ while.body.184: ; preds = %while.hdr.183 while.exit.185: ; preds = %while.hdr.183 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.482, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.484, i64 1 }) ret { ptr, i64 } %callN if.then.186: ; preds = %while.body.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.483, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.485, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.187 if.merge.187: ; preds = %if.then.186, %while.body.184 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.489, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.491, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.490, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.492, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5026,7 +5035,7 @@ define internal { ptr, i64 } @struct_to_string__Array(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 5 }, { ptr, i64 } { ptr @str.492, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.493, i64 5 }, { ptr, i64 } { ptr @str.494, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5045,24 +5054,24 @@ while.body.189: ; preds = %while.hdr.188 while.exit.190: ; preds = %while.hdr.188 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.493, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.495, i64 1 }) ret { ptr, i64 } %callN if.then.191: ; preds = %while.body.189 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.494, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.192 if.merge.192: ; preds = %if.then.191, %while.body.189 %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.498, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.500, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.499, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.501, 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 @@ -5108,7 +5117,7 @@ define internal { ptr, i64 } @struct_to_string__Object(ptr %0, { ptr, i64, i64 } entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 6 }, { ptr, i64 } { ptr @str.501, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 6 }, { ptr, i64 } { ptr @str.503, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5127,24 +5136,24 @@ while.body.194: ; preds = %while.hdr.193 while.exit.195: ; preds = %while.hdr.193 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.502, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.504, i64 1 }) ret { ptr, i64 } %callN if.then.196: ; preds = %while.body.194 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.503, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.505, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.197 if.merge.197: ; preds = %if.then.196, %while.body.194 %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.507, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.509, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.510, 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 @@ -5192,7 +5201,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp19 = alloca { i64, [24 x i8] }, align 8 store { { ptr, i64 }, { i64, [24 x i8] } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.509, i64 6 }, { ptr, i64 } { ptr @str.510, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.511, i64 6 }, { ptr, i64 } { ptr @str.512, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5211,24 +5220,24 @@ while.body.199: ; preds = %while.hdr.198 while.exit.200: ; preds = %while.hdr.198 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.513, i64 1 }) ret { ptr, i64 } %callN if.then.201: ; preds = %while.body.199 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.512, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.514, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.202 if.merge.202: ; preds = %if.then.201, %while.body.199 %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.515, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.517, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.516, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.518, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5272,7 +5281,7 @@ entry: %alloca = alloca { { ptr, i64 }, i64, ptr }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i64, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 4 }, { ptr, i64 } { ptr @str.518, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.519, i64 4 }, { ptr, i64 } { ptr @str.520, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5291,24 +5300,24 @@ while.body.204: ; preds = %while.hdr.203 while.exit.205: ; preds = %while.hdr.203 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.519, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.521, i64 1 }) ret { ptr, i64 } %callN if.then.206: ; preds = %while.body.204 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.520, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.207 if.merge.207: ; preds = %if.then.206, %while.body.204 %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.524, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.526, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.525, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.527, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5358,7 +5367,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 %ba.tmp22 = alloca { ptr, ptr, ptr }, align 8 store { { ptr, i64 }, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 6 }, { ptr, i64 } { ptr @str.527, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.528, i64 6 }, { ptr, i64 } { ptr @str.529, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5377,24 +5386,24 @@ while.body.209: ; preds = %while.hdr.208 while.exit.210: ; preds = %while.hdr.208 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.528, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.530, i64 1 }) ret { ptr, i64 } %callN if.then.211: ; preds = %while.body.209 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.529, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.531, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.212 if.merge.212: ; preds = %if.then.211, %while.body.209 %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.533, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.535, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.534, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.536, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5434,7 +5443,7 @@ fv.case20: ; preds = %if.merge.212 %fv.field21 = extractvalue { { ptr, i64 }, i64, { ptr, ptr, ptr } } %loadN, 2 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp22, align 8 %ba.p2i23 = ptrtoint ptr %ba.tmp22 to i64 - %fv.val24 = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %ba.p2i23, 1 + %fv.val24 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i23, 1 br label %fv.merge } @@ -5443,7 +5452,7 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.535, i64 12 }, { ptr, i64 } { ptr @str.536, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.537, i64 12 }, { ptr, i64 } { ptr @str.538, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5462,24 +5471,24 @@ while.body.214: ; preds = %while.hdr.213 while.exit.215: ; preds = %while.hdr.213 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.537, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.539, i64 1 }) ret { ptr, i64 } %callN if.then.216: ; preds = %while.body.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.538, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.217 if.merge.217: ; preds = %if.then.216, %while.body.214 %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.539, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.541, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.540, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.542, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5499,7 +5508,7 @@ entry: %alloca = alloca { { ptr, i64 }, i1, i1 }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, i1, i1 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.541, i64 8 }, { ptr, i64 } { ptr @str.542, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.543, i64 8 }, { ptr, i64 } { ptr @str.544, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5518,24 +5527,24 @@ while.body.219: ; preds = %while.hdr.218 while.exit.220: ; preds = %while.hdr.218 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.545, i64 1 }) ret { ptr, i64 } %callN if.then.221: ; preds = %while.body.219 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.546, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.222 if.merge.222: ; preds = %if.then.221, %while.body.219 %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.548, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.550, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.549, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5587,7 +5596,7 @@ entry: %ba.tmp19 = alloca { ptr, i64 }, align 8 %ba.tmp24 = alloca { ptr, i64 }, align 8 store { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.550, i64 7 }, { ptr, i64 } { ptr @str.551, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.552, i64 7 }, { ptr, i64 } { ptr @str.553, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5606,24 +5615,24 @@ while.body.224: ; preds = %while.hdr.223 while.exit.225: ; preds = %while.hdr.223 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.554, i64 1 }) ret { ptr, i64 } %callN if.then.226: ; preds = %while.body.224 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.553, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.555, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.227 if.merge.227: ; preds = %if.then.226, %while.body.224 %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.557, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.559, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.558, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.560, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5675,7 +5684,7 @@ entry: %alloca = alloca { i1, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i1, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, i64 9 }, { ptr, i64 } { ptr @str.560, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.561, i64 9 }, { ptr, i64 } { ptr @str.562, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5694,24 +5703,24 @@ while.body.229: ; preds = %while.hdr.228 while.exit.230: ; preds = %while.hdr.228 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.561, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.563, i64 1 }) ret { ptr, i64 } %callN if.then.231: ; preds = %while.body.229 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.562, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.564, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.232 if.merge.232: ; preds = %if.then.231, %while.body.229 %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.565, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.567, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.568, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5754,7 +5763,7 @@ entry: %alloca = alloca { i64, { ptr, i64 } }, align 8 %ba.tmp = alloca { ptr, i64 }, align 8 store { i64, { ptr, i64 } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, i64 4 }, { ptr, i64 } { ptr @str.568, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.569, i64 4 }, { ptr, i64 } { ptr @str.570, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5773,24 +5782,24 @@ while.body.234: ; preds = %while.hdr.233 while.exit.235: ; preds = %while.hdr.233 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.569, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.571, i64 1 }) ret { ptr, i64 } %callN if.then.236: ; preds = %while.body.234 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.570, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.572, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.237 if.merge.237: ; preds = %if.then.236, %while.body.234 %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.573, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.575, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.576, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5836,7 +5845,7 @@ entry: %ba.tmp35 = alloca { ptr, i64 }, align 8 %ba.tmp40 = alloca [16 x { i1, { ptr, i64 } }], align 8 store { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, i64 6 }, { ptr, i64 } { ptr @str.576, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, i64 6 }, { ptr, i64 } { ptr @str.578, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5855,24 +5864,24 @@ while.body.239: ; preds = %while.hdr.238 while.exit.240: ; preds = %while.hdr.238 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.577, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, i64 1 }) ret { ptr, i64 } %callN if.then.241: ; preds = %while.body.239 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.578, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.580, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.242 if.merge.242: ; preds = %if.then.241, %while.body.239 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.586, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.588, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.587, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.589, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5954,7 +5963,7 @@ entry: %ba.tmp = alloca [8 x i64], align 8 %ba.tmp19 = alloca [64 x i8], align 1 store { [8 x i64], [64 x i8], i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 6 }, { ptr, i64 } { ptr @str.589, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, i64 6 }, { ptr, i64 } { ptr @str.591, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5973,24 +5982,24 @@ while.body.244: ; preds = %while.hdr.243 while.exit.245: ; preds = %while.hdr.243 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, i64 1 }) ret { ptr, i64 } %callN if.then.246: ; preds = %while.body.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.593, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.247 if.merge.247: ; preds = %if.then.246, %while.body.244 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.598, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.599, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6045,7 +6054,7 @@ define internal { ptr, i64 } @struct_to_string__NSString(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.598, i64 8 }, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.600, i64 8 }, { ptr, i64 } { ptr @str.601, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6064,24 +6073,24 @@ while.body.249: ; preds = %while.hdr.248 while.exit.250: ; preds = %while.hdr.248 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.602, i64 1 }) ret { ptr, i64 } %callN if.then.251: ; preds = %while.body.249 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.601, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.252 if.merge.252: ; preds = %if.then.251, %while.body.249 %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.602, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.604, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.605, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6100,7 +6109,7 @@ define internal { ptr, i64 } @struct_to_string__Triple(ptr %0, { i64, i64, i64 } entry: %alloca = alloca { i64, i64, i64 }, align 8 store { i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.604, i64 6 }, { ptr, i64 } { ptr @str.605, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.606, i64 6 }, { ptr, i64 } { ptr @str.607, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6119,24 +6128,24 @@ while.body.254: ; preds = %while.hdr.253 while.exit.255: ; preds = %while.hdr.253 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.608, i64 1 }) ret { ptr, i64 } %callN if.then.256: ; preds = %while.body.254 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.607, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.609, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.257 if.merge.257: ; preds = %if.then.256, %while.body.254 %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.611, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.613, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.612, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, 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 @@ -6185,9 +6194,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.618, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.620, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.613, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.615, 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 @@ -6206,8 +6215,8 @@ entry: if.then.265: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.619, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.622, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -6226,9 +6235,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.625, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.627, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.623, 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 @@ -6247,8 +6256,8 @@ entry: if.then.267: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.626, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.629, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -6278,9 +6287,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %etag, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.635, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.637, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.630, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { i64, [24 x i8] }, ptr %alloca, align 8 @@ -6297,8 +6306,8 @@ entry: if.then.269: ; preds = %fv.merge %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.637, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.639, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 @@ -6376,9 +6385,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.646, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.648, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.638, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, 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 @@ -6397,8 +6406,8 @@ entry: if.then.271: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.648, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.650, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 @@ -6417,9 +6426,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.655, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.657, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.651, 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 @@ -6438,8 +6447,8 @@ entry: if.then.273: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.657, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.274 @@ -6456,7 +6465,7 @@ entry: %ig.tmp = alloca [4 x i64], align 8 store [4 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.658, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.660, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.284 @@ -6473,12 +6482,12 @@ while.body.285: ; preds = %while.hdr.284 while.exit.286: ; preds = %while.hdr.284 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.661, i64 1 }) ret { ptr, i64 } %call if.then.287: ; preds = %while.body.285 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.660, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.288 @@ -6507,7 +6516,7 @@ entry: %ba.tmp = alloca { i1, { ptr, i64 } }, align 8 store [16 x { i1, { ptr, i64 } }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.661, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.663, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.289 @@ -6524,12 +6533,12 @@ while.body.290: ; preds = %while.hdr.289 while.exit.291: ; preds = %while.hdr.289 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.662, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.664, i64 1 }) ret { ptr, i64 } %call if.then.292: ; preds = %while.body.290 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.663, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.293 @@ -6559,7 +6568,7 @@ entry: %ig.tmp = alloca [8 x i64], align 8 store [8 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.664, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.666, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.294 @@ -6576,12 +6585,12 @@ while.body.295: ; preds = %while.hdr.294 while.exit.296: ; preds = %while.hdr.294 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.665, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, i64 1 }) ret { ptr, i64 } %call if.then.297: ; preds = %while.body.295 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.666, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.298 @@ -6609,7 +6618,7 @@ entry: %ig.tmp = alloca [64 x i8], align 1 store [64 x i8] %1, ptr %alloca, align 1 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.667, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.669, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.299 @@ -6626,12 +6635,12 @@ while.body.300: ; preds = %while.hdr.299 while.exit.301: ; preds = %while.hdr.299 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.668, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, i64 1 }) ret { ptr, i64 } %call if.then.302: ; preds = %while.body.300 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.303 @@ -6660,7 +6669,7 @@ entry: %ig.tmp = alloca [64 x i64], align 8 store [64 x i64] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.670, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.672, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.304 @@ -6677,12 +6686,12 @@ while.body.305: ; preds = %while.hdr.304 while.exit.306: ; preds = %while.hdr.304 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.673, i64 1 }) ret { ptr, i64 } %call if.then.307: ; preds = %while.body.305 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.308 @@ -6711,7 +6720,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.673, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.675, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.309 @@ -6728,12 +6737,12 @@ while.body.310: ; preds = %while.hdr.309 while.exit.311: ; preds = %while.hdr.309 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.676, i64 1 }) ret { ptr, i64 } %call if.then.312: ; preds = %while.body.310 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.313 @@ -6764,7 +6773,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.676, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.678, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.314 @@ -6781,12 +6790,12 @@ while.body.315: ; preds = %while.hdr.314 while.exit.316: ; preds = %while.hdr.314 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 1 }) ret { ptr, i64 } %call if.then.317: ; preds = %while.body.315 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.318 @@ -6816,7 +6825,7 @@ entry: %ba.tmp = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.679, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.681, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.326 @@ -6835,12 +6844,12 @@ while.body.327: ; preds = %while.hdr.326 while.exit.328: ; preds = %while.hdr.326 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 1 }) ret { ptr, i64 } %call if.then.329: ; preds = %while.body.327 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.681, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.330 @@ -6869,7 +6878,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.682, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.684, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.331 @@ -6888,12 +6897,12 @@ while.body.332: ; preds = %while.hdr.331 while.exit.333: ; preds = %while.hdr.331 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 1 }) ret { ptr, i64 } %call if.then.334: ; preds = %while.body.332 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.684, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.335 @@ -6922,7 +6931,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, i1, i1 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.685, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.687, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.336 @@ -6941,12 +6950,12 @@ while.body.337: ; preds = %while.hdr.336 while.exit.338: ; preds = %while.hdr.336 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 1 }) ret { ptr, i64 } %call if.then.339: ; preds = %while.body.337 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.687, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.340 @@ -6976,7 +6985,7 @@ entry: %ba.tmp = alloca { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.688, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.690, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.341 @@ -6995,12 +7004,12 @@ while.body.342: ; preds = %while.hdr.341 while.exit.343: ; preds = %while.hdr.341 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, i64 1 }) ret { ptr, i64 } %call if.then.344: ; preds = %while.body.342 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.690, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.345 @@ -7030,7 +7039,7 @@ entry: %ba.tmp = alloca { i64, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.691, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.693, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.346 @@ -7049,12 +7058,12 @@ while.body.347: ; preds = %while.hdr.346 while.exit.348: ; preds = %while.hdr.346 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, i64 1 }) ret { ptr, i64 } %call if.then.349: ; preds = %while.body.347 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.695, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.350 @@ -7096,12 +7105,12 @@ if.then.386: ; preds = %entry if.else.387: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 5 }, { ptr, i64 } %callN) br label %if.merge.388 if.merge.388: ; preds = %if.else.387, %if.then.386 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] ret { ptr, i64 } %bp } @@ -7124,12 +7133,12 @@ if.then.402: ; preds = %entry if.else.403: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.699, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 11 }, { ptr, i64 } %callN) br label %if.merge.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -7152,12 +7161,12 @@ if.then.405: ; preds = %entry if.else.406: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 4 }, { ptr, i64 } %callN) br label %if.merge.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -7180,12 +7189,12 @@ if.then.408: ; preds = %entry if.else.409: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 11 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 11 }, { ptr, i64 } %callN) br label %if.merge.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7208,12 +7217,12 @@ if.then.411: ; preds = %entry if.else.412: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 6 }, { ptr, i64 } %callN) br label %if.merge.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7235,12 +7244,12 @@ if.then.414: ; preds = %entry if.else.415: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 5 }, { ptr, i64 } %callN) br label %if.merge.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7263,12 +7272,12 @@ if.then.417: ; preds = %entry if.else.418: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 9 }, { ptr, i64 } %callN) br label %if.merge.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7291,12 +7300,12 @@ if.then.420: ; preds = %entry if.else.421: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 18 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 18 }, { ptr, i64 } %callN) br label %if.merge.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7319,12 +7328,12 @@ if.then.423: ; preds = %entry if.else.424: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 5 }, { ptr, i64 } %callN) br label %if.merge.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7347,12 +7356,12 @@ if.then.426: ; preds = %entry if.else.427: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 3 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.724, i64 3 }, { ptr, i64 } %callN) br label %if.merge.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7375,12 +7384,12 @@ if.then.429: ; preds = %entry if.else.430: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.727, i64 4 }, { ptr, i64 } %callN) br label %if.merge.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7403,12 +7412,12 @@ if.then.432: ; preds = %entry if.else.433: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.730, i64 9 }, { ptr, i64 } %callN) br label %if.merge.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7431,12 +7440,12 @@ if.then.435: ; preds = %entry if.else.436: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.731, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 4 }, { ptr, i64 } %callN) br label %if.merge.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7458,12 +7467,12 @@ if.then.438: ; preds = %entry if.else.439: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 8 }, { ptr, i64 } %callN) br label %if.merge.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7486,12 +7495,12 @@ if.then.441: ; preds = %entry if.else.442: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.739, i64 6 }, { ptr, i64 } %callN) br label %if.merge.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7513,12 +7522,12 @@ if.then.444: ; preds = %entry if.else.445: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.742, i64 9 }, { ptr, i64 } %callN) br label %if.merge.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7541,12 +7550,12 @@ if.then.447: ; preds = %entry if.else.448: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 7 }, { ptr, i64 } %callN) br label %if.merge.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7569,12 +7578,12 @@ if.then.450: ; preds = %entry if.else.451: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.748, i64 5 }, { ptr, i64 } %callN) br label %if.merge.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7597,12 +7606,12 @@ if.then.453: ; preds = %entry if.else.454: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.749, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.751, i64 7 }, { ptr, i64 } %callN) br label %if.merge.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7625,12 +7634,12 @@ if.then.456: ; preds = %entry if.else.457: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 4 }, { ptr, i64 } %callN) br label %if.merge.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7653,12 +7662,12 @@ if.then.459: ; preds = %entry if.else.460: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.757, i64 7 }, { ptr, i64 } %callN) br label %if.merge.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7681,12 +7690,12 @@ if.then.462: ; preds = %entry if.else.463: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.760, i64 5 }, { ptr, i64 } %callN) br label %if.merge.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7709,12 +7718,12 @@ if.then.465: ; preds = %entry if.else.466: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.763, i64 7 }, { ptr, i64 } %callN) br label %if.merge.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7737,12 +7746,12 @@ if.then.468: ; preds = %entry if.else.469: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 9 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.766, i64 9 }, { ptr, i64 } %callN) br label %if.merge.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7765,12 +7774,12 @@ if.then.471: ; preds = %entry if.else.472: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.769, i64 12 }, { ptr, i64 } %callN) br label %if.merge.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7793,12 +7802,12 @@ if.then.474: ; preds = %entry if.else.475: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 6 }, { ptr, i64 } %callN) br label %if.merge.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7821,12 +7830,12 @@ if.then.477: ; preds = %entry if.else.478: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.775, i64 5 }, { ptr, i64 } %callN) br label %if.merge.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7849,12 +7858,12 @@ if.then.480: ; preds = %entry if.else.481: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.778, i64 7 }, { ptr, i64 } %callN) br label %if.merge.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7877,12 +7886,12 @@ if.then.483: ; preds = %entry if.else.484: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.781, i64 4 }, { ptr, i64 } %callN) br label %if.merge.485 if.merge.485: ; preds = %if.else.484, %if.then.483 - %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -7905,12 +7914,12 @@ if.then.486: ; preds = %entry if.else.487: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.784, i64 7 }, { ptr, i64 } %callN) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -7933,12 +7942,12 @@ if.then.489: ; preds = %entry if.else.490: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.787, i64 6 }, { ptr, i64 } %callN) br label %if.merge.491 if.merge.491: ; preds = %if.else.490, %if.then.489 - %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -7961,12 +7970,12 @@ if.then.492: ; preds = %entry if.else.493: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 7 }, { ptr, i64 } %callN) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -7989,12 +7998,12 @@ if.then.495: ; preds = %entry if.else.496: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.793, i64 7 }, { ptr, i64 } %callN) br label %if.merge.497 if.merge.497: ; preds = %if.else.496, %if.then.495 - %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -8010,7 +8019,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.793, i64 4 } + ret { ptr, i64 } { ptr @str.795, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8034,7 +8043,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.794, i64 4 } + ret { ptr, i64 } { ptr @str.796, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8058,7 +8067,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.795, i64 4 } + ret { ptr, i64 } { ptr @str.797, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8082,7 +8091,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.796, i64 4 } + ret { ptr, i64 } { ptr @str.798, i64 4 } if.merge.511: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/1347-ffi-objc-dsl-07-mangling-table.ir b/examples/expected/1347-ffi-objc-dsl-07-mangling-table.ir index 26ce18c..27d68f9 100644 --- a/examples/expected/1347-ffi-objc-dsl-07-mangling-table.ir +++ b/examples/expected/1347-ffi-objc-dsl-07-mangling-table.ir @@ -8,47 +8,47 @@ @OBJC_SELECTOR_REFERENCES_initWithFrame_options_ = internal global ptr null @OBJC_SELECTOR_REFERENCES_actualSelectorName = internal global ptr null @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.162 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.163 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.164 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.165 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.166 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.167 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.168 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.169 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.170 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.171 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.172 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.173 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.174 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.175 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.176 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.177 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 -@str.178 = private unnamed_addr constant [16 x i8] c"SxManglingProbe\00", align 1 -@str.179 = private unnamed_addr constant [7 x i8] c"length\00", align 1 -@str.180 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 -@str.181 = private unnamed_addr constant [11 x i8] c"addObject:\00", align 1 -@str.182 = private unnamed_addr constant [5 x i8] c"i@:i\00", align 1 -@str.183 = private unnamed_addr constant [13 x i8] c"combine:and:\00", align 1 -@str.184 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 -@str.185 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00", align 1 -@str.186 = private unnamed_addr constant [7 x i8] c"i@:iii\00", align 1 -@str.187 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00", align 1 -@str.188 = private unnamed_addr constant [8 x i8] c"i@:iiii\00", align 1 -@str.189 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00", align 1 -@str.190 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 -@str.191 = private unnamed_addr constant [19 x i8] c"actualSelectorName\00", align 1 -@str.192 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 -@str.193 = private unnamed_addr constant [19 x i8] c"mangling table OK\0A\00", align 1 -@str.194 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.164 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.165 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.166 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.168 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.169 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.170 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.171 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.172 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.173 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.174 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.175 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.176 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.177 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.178 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.179 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 +@str.180 = private unnamed_addr constant [16 x i8] c"SxManglingProbe\00", align 1 +@str.181 = private unnamed_addr constant [7 x i8] c"length\00", align 1 +@str.182 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 +@str.183 = private unnamed_addr constant [11 x i8] c"addObject:\00", align 1 +@str.184 = private unnamed_addr constant [5 x i8] c"i@:i\00", align 1 +@str.185 = private unnamed_addr constant [13 x i8] c"combine:and:\00", align 1 +@str.186 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 +@str.187 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00", align 1 +@str.188 = private unnamed_addr constant [7 x i8] c"i@:iii\00", align 1 +@str.189 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00", align 1 +@str.190 = private unnamed_addr constant [8 x i8] c"i@:iiii\00", align 1 +@str.191 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00", align 1 +@str.192 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 +@str.193 = private unnamed_addr constant [19 x i8] c"actualSelectorName\00", align 1 +@str.194 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 @str.195 = private unnamed_addr constant [19 x i8] c"mangling table OK\0A\00", align 1 +@str.196 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.197 = private unnamed_addr constant [19 x i8] c"mangling table OK\0A\00", align 1 @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [7 x i8] c"length\00" -@OBJC_METH_VAR_NAME_.196 = private unnamed_addr constant [11 x i8] c"addObject:\00" -@OBJC_METH_VAR_NAME_.197 = private unnamed_addr constant [13 x i8] c"combine:and:\00" -@OBJC_METH_VAR_NAME_.198 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00" -@OBJC_METH_VAR_NAME_.199 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00" -@OBJC_METH_VAR_NAME_.200 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00" -@OBJC_METH_VAR_NAME_.201 = private unnamed_addr constant [19 x i8] c"actualSelectorName\00" +@OBJC_METH_VAR_NAME_.198 = private unnamed_addr constant [11 x i8] c"addObject:\00" +@OBJC_METH_VAR_NAME_.199 = private unnamed_addr constant [13 x i8] c"combine:and:\00" +@OBJC_METH_VAR_NAME_.200 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00" +@OBJC_METH_VAR_NAME_.201 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00" +@OBJC_METH_VAR_NAME_.202 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00" +@OBJC_METH_VAR_NAME_.203 = private unnamed_addr constant [19 x i8] c"actualSelectorName\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 @@ -62,6 +62,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -354,7 +357,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.162, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.164, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -450,7 +453,7 @@ if.merge.11: ; preds = %if.merge.25, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.163, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -458,7 +461,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.164, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -468,13 +471,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -482,7 +485,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -496,7 +499,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.23: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -504,7 +507,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -515,7 +518,7 @@ if.then.23: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -572,7 +575,7 @@ if.merge.31: ; preds = %if.merge.34, %if.el if.then.32: ; preds = %if.then.29 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -580,7 +583,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -591,7 +594,7 @@ if.then.32: ; preds = %if.then.29 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -611,7 +614,7 @@ if.merge.34: ; preds = %if.else.33, %if.the if.then.35: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -619,7 +622,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -630,7 +633,7 @@ if.then.35: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -640,64 +643,67 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -873,163 +879,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1227,64 +1236,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1314,97 +1323,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1443,118 +1452,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -1636,17 +1645,14 @@ entry: define i32 @main() #0 { entry: call void @__sx_objc_selector_init() - %call = call ptr @objc_getClass(ptr @str.177) + %call = call ptr @objc_getClass(ptr @str.179) %alloca = alloca ptr, align 8 store ptr %call, ptr %alloca, align 8 %load = load ptr, ptr %alloca, align 8 - %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.178, i64 0) + %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.180, i64 0) %allocaN = alloca ptr, align 8 store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.179) - %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.180) - %loadN = load ptr, ptr %allocaN, align 8 %callN = call ptr @sel_registerName(ptr @str.181) %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.182) %loadN = load ptr, ptr %allocaN, align 8 @@ -1665,6 +1671,9 @@ entry: %callN = call ptr @sel_registerName(ptr @str.191) %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.192) %loadN = load ptr, ptr %allocaN, align 8 + %callN = call ptr @sel_registerName(ptr @str.193) + %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.194) + %loadN = load ptr, ptr %allocaN, align 8 call void @objc_registerClassPair(ptr %loadN) %allocaN = alloca ptr, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -1713,14 +1722,14 @@ entry: define internal void @print__ct_s4c1a58a7c89bfbba__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.193, i64 18 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.195, i64 18 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.194, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.196, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 18) @@ -1736,7 +1745,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.195, i64 18 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.197, i64 18 }) ret { ptr, i64 } %call } @@ -1744,17 +1753,17 @@ 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_length, align 8 - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.196) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_addObject_, align 8 - %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.197) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_combine_and_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.198) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_insert_after_index_, align 8 + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_addObject_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.199) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_add_observer_for_event_, align 8 + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_combine_and_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.200) - store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_initWithFrame_options_, align 8 + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_insert_after_index_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.201) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_add_observer_for_event_, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.202) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_initWithFrame_options_, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.203) store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_actualSelectorName, align 8 ret void } diff --git a/examples/expected/1402-ffi-jni-call-03-methodid-sharing.ir b/examples/expected/1402-ffi-jni-call-03-methodid-sharing.ir index 91a3964..c68b01a 100644 --- a/examples/expected/1402-ffi-jni-call-03-methodid-sharing.ir +++ b/examples/expected/1402-ffi-jni-call-03-methodid-sharing.ir @@ -2,30 +2,30 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 -@SX_JNI_CLS_noop____V = internal global ptr null -@SX_JNI_MID_noop____V = internal global ptr null +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.142 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 @str.143 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 -@str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@SX_JNI_CLS_noop____V = internal global ptr null +@SX_JNI_MID_noop____V = internal global ptr null +@str.144 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 +@str.145 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 @str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.147 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.148 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -38,6 +38,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -330,7 +333,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -426,7 +429,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -434,7 +437,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -444,13 +447,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -458,7 +461,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -472,7 +475,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -480,7 +483,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -491,7 +494,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -548,7 +551,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -556,7 +559,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -567,7 +570,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -587,7 +590,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -595,7 +598,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -606,7 +609,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -616,64 +619,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -849,163 +855,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1203,64 +1212,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1290,97 +1299,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1419,7 +1428,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1447,7 +1456,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_noop____V, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont @@ -1472,7 +1481,7 @@ jni.miss7: ; preds = %jni.cont store ptr %jni.global.cls12, ptr @SX_JNI_CLS_noop____V, align 8 %9 = getelementptr inbounds ptr, ptr %jni.ifs4, i32 33 %jni.GetMethodID13 = load ptr, ptr %9, align 8 - %jni.fresh.mid14 = call ptr %jni.GetMethodID13(ptr %load, ptr %jni.global.cls12, ptr @str.142, ptr @str.143) + %jni.fresh.mid14 = call ptr %jni.GetMethodID13(ptr %load, ptr %jni.global.cls12, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid14, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont8 @@ -1524,14 +1533,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.146, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.147, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1547,6 +1556,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.148, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1403-ffi-jni-call-04-jint-return.ir b/examples/expected/1403-ffi-jni-call-04-jint-return.ir index 6c58368..f128899 100644 --- a/examples/expected/1403-ffi-jni-call-04-jint-return.ir +++ b/examples/expected/1403-ffi-jni-call-04-jint-return.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [9 x i8] c"getCount\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()I\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [9 x i8] c"getCount\00", align 1 +@str.143 = private unnamed_addr constant [4 x i8] c"()I\00", align 1 @SX_JNI_CLS_getCount____I = internal global ptr null @SX_JNI_MID_getCount____I = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @read_int(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_getCount____I, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getCount____I, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1404-ffi-jni-call-05-jlong-return.ir b/examples/expected/1404-ffi-jni-call-05-jlong-return.ir index bbd6b0b..70a624d 100644 --- a/examples/expected/1404-ffi-jni-call-05-jlong-return.ir +++ b/examples/expected/1404-ffi-jni-call-05-jlong-return.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [18 x i8] c"currentTimeMillis\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()J\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [18 x i8] c"currentTimeMillis\00", align 1 +@str.143 = private unnamed_addr constant [4 x i8] c"()J\00", align 1 @SX_JNI_CLS_currentTimeMillis____J = internal global ptr null @SX_JNI_MID_currentTimeMillis____J = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @read_long(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_currentTimeMillis____J, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_currentTimeMillis____J, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1405-ffi-jni-call-06-jdouble-return.ir b/examples/expected/1405-ffi-jni-call-06-jdouble-return.ir index e618f90..b84ab48 100644 --- a/examples/expected/1405-ffi-jni-call-06-jdouble-return.ir +++ b/examples/expected/1405-ffi-jni-call-06-jdouble-return.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [9 x i8] c"getValue\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()D\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [9 x i8] c"getValue\00", align 1 +@str.143 = private unnamed_addr constant [4 x i8] c"()D\00", align 1 @SX_JNI_CLS_getValue____D = internal global ptr null @SX_JNI_MID_getValue____D = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal double @read_double(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_getValue____D, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getValue____D, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1406-ffi-jni-call-07-jboolean-return.ir b/examples/expected/1406-ffi-jni-call-07-jboolean-return.ir index fa7b845..2d53836 100644 --- a/examples/expected/1406-ffi-jni-call-07-jboolean-return.ir +++ b/examples/expected/1406-ffi-jni-call-07-jboolean-return.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [8 x i8] c"isShown\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()Z\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [8 x i8] c"isShown\00", align 1 +@str.143 = private unnamed_addr constant [4 x i8] c"()Z\00", align 1 @SX_JNI_CLS_isShown____Z = internal global ptr null @SX_JNI_MID_isShown____Z = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i1 @read_bool(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_isShown____Z, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_isShown____Z, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1407-ffi-jni-call-08-jobject-return.ir b/examples/expected/1407-ffi-jni-call-08-jobject-return.ir index b26791d..46bfb6b 100644 --- a/examples/expected/1407-ffi-jni-call-08-jobject-return.ir +++ b/examples/expected/1407-ffi-jni-call-08-jobject-return.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 -@str.141 = private unnamed_addr constant [24 x i8] c"()Landroid/view/Window;\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 +@str.143 = private unnamed_addr constant [24 x i8] c"()Landroid/view/Window;\00", align 1 @SX_JNI_CLS_getWindow____Landroid_view_Window_ = internal global ptr null @SX_JNI_MID_getWindow____Landroid_view_Window_ = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal ptr @get_window(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_getWindow____Landroid_view_Window_, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getWindow____Landroid_view_Window_, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1408-ffi-jni-call-09-static.ir b/examples/expected/1408-ffi-jni-call-09-static.ir index 321669b..f5137c7 100644 --- a/examples/expected/1408-ffi-jni-call-09-static.ir +++ b/examples/expected/1408-ffi-jni-call-09-static.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [4 x i8] c"max\00", align 1 -@str.141 = private unnamed_addr constant [6 x i8] c"(II)I\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [4 x i8] c"max\00", align 1 +@str.143 = private unnamed_addr constant [6 x i8] c"(II)I\00", align 1 @SX_JNI_CLS_max___II_I = internal global ptr null @SX_JNI_MID_max___II_I = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @call_static_max(ptr %0, ptr %1, ptr %2) #0 { @@ -1442,7 +1451,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_max___II_I, align 8 %4 = getelementptr inbounds ptr, ptr %jni.ifs, i32 113 %jni.GetStaticMethodID = load ptr, ptr %4, align 8 - %jni.fresh.mid = call ptr %jni.GetStaticMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetStaticMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_max___II_I, align 8 br label %jni.cont @@ -1496,14 +1505,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1519,6 +1528,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1418-ffi-jni-class-08-call.ir b/examples/expected/1418-ffi-jni-class-08-call.ir index 9162495..89afc57 100644 --- a/examples/expected/1418-ffi-jni-class-08-call.ir +++ b/examples/expected/1418-ffi-jni-class-08-call.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 -@str.141 = private unnamed_addr constant [21 x i8] c"()Ljava/lang/Object;\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 +@str.143 = private unnamed_addr constant [21 x i8] c"()Ljava/lang/Object;\00", align 1 @SX_JNI_CLS_getWindow____Ljava_lang_Object_ = internal global ptr null @SX_JNI_MID_getWindow____Ljava_lang_Object_ = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1446,7 +1455,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_getWindow____Ljava_lang_Object_, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getWindow____Ljava_lang_Object_, align 8 br label %jni.cont @@ -1499,14 +1508,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1522,6 +1531,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1421-ffi-jni-env-02-lexical-direct.ir b/examples/expected/1421-ffi-jni-env-02-lexical-direct.ir index 486023c..1d30bb1 100644 --- a/examples/expected/1421-ffi-jni-env-02-lexical-direct.ir +++ b/examples/expected/1421-ffi-jni-env-02-lexical-direct.ir @@ -2,28 +2,28 @@ @g_should_call = internal global i1 false @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [2 x i8] c"0\00", align 1 -@str.125 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.126 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.128 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.129 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.130 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.131 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.132 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.133 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.134 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.135 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.136 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.137 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.138 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.139 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.140 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 -@str.141 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 +@str.127 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.128 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.131 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.133 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.134 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.135 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.136 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.138 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.139 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.141 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.142 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 +@str.143 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 @SX_JNI_CLS_noop____V = internal global ptr null @SX_JNI_MID_noop____V = internal global ptr null -@str.142 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 -@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.144 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.145 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.146 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -36,6 +36,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -328,7 +331,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.125, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.127, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -424,7 +427,7 @@ if.merge.13: ; preds = %if.merge.27, %if.me if.then.14: ; preds = %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -432,7 +435,7 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -442,13 +445,13 @@ if.then.14: ; preds = %if.then.11 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.15 if.merge.15: ; preds = %if.then.14, %if.then.11 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -456,7 +459,7 @@ if.merge.15: ; preds = %if.then.14, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -470,7 +473,7 @@ if.merge.15: ; preds = %if.then.14, %if.the if.then.25: ; preds = %if.else.12 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -478,7 +481,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -489,7 +492,7 @@ if.then.25: ; preds = %if.else.12 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -546,7 +549,7 @@ if.merge.33: ; preds = %if.merge.36, %if.el if.then.34: ; preds = %if.then.31 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -554,7 +557,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -565,7 +568,7 @@ if.then.34: ; preds = %if.then.31 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -585,7 +588,7 @@ if.merge.36: ; preds = %if.else.35, %if.the if.then.37: ; preds = %while.exit.4 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -593,7 +596,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -604,7 +607,7 @@ if.then.37: ; preds = %while.exit.4 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -614,64 +617,67 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -847,163 +853,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1201,64 +1210,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1288,97 +1297,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1417,7 +1426,7 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1445,7 +1454,7 @@ jni.miss: ; preds = %entry store ptr %jni.global.cls, ptr @SX_JNI_CLS_noop____V, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %5, align 8 - %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.140, ptr @str.141) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.142, ptr @str.143) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont @@ -1497,14 +1506,14 @@ declare void @sx_jni_env_tl_set(ptr) #0 define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.142, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.144, i64 3 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 %gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0 store ptr null, ptr %gep, align 8 %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 0, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.143, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.145, i64 0 }, ptr %allocaN, align 8 %load = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 3) @@ -1520,6 +1529,6 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.144, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.146, i64 3 }) ret { ptr, i64 } %call } diff --git a/examples/expected/1425-ffi-jni-main-03-ctor.ir b/examples/expected/1425-ffi-jni-main-03-ctor.ir index 66c42e0..a8d890c 100644 --- a/examples/expected/1425-ffi-jni-main-03-ctor.ir +++ b/examples/expected/1425-ffi-jni-main-03-ctor.ir @@ -2,10 +2,10 @@ @g_held_view = internal global ptr null @__sx_default_context = internal constant { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc_bytes, ptr @__thunk_CAllocator_Allocator_dealloc_bytes }, ptr null } @str = private unnamed_addr constant [9 x i8] c"onCreate\00", align 1 -@str.162 = private unnamed_addr constant [23 x i8] c"(Landroid/os/Bundle;)V\00", align 1 +@str.164 = private unnamed_addr constant [23 x i8] c"(Landroid/os/Bundle;)V\00", align 1 @jni.parent.path = private unnamed_addr constant [21 x i8] c"android/app/Activity\00", align 1 -@str.163 = private unnamed_addr constant [7 x i8] c"\00", align 1 -@str.164 = private unnamed_addr constant [29 x i8] c"(Landroid/content/Context;)V\00", align 1 +@str.165 = private unnamed_addr constant [7 x i8] c"\00", align 1 +@str.166 = private unnamed_addr constant [29 x i8] c"(Landroid/content/Context;)V\00", align 1 @jni.ctor.path = private unnamed_addr constant [25 x i8] c"android/view/SurfaceView\00", align 1 ; Function Attrs: nounwind @@ -19,6 +19,9 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 + ; Function Attrs: nounwind define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { entry: @@ -137,64 +140,67 @@ declare ptr @any_to_string(ptr, [2 x i64]) #0 declare ptr @build_format(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.1(ptr, ptr, i64) #0 +declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.2(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.3(ptr) #0 +declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.4(ptr, ptr, i64) #0 +declare i64 @GPA.init.4(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.5(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.6(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.7(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.8(ptr, ptr) #0 +declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.9(ptr, ptr) #0 +declare void @Arena.reset.9(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.10(ptr, ptr, i64) #0 +declare void @Arena.deinit.10(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.11(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.12(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.13(ptr, ptr) #0 +declare ptr @BufAlloc.init.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.14(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.14(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.15(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.16(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.17(ptr, ptr) #0 +declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.18(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.19(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.19(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.20(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -370,163 +376,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.21(i32, ptr, i64) #0 +declare i64 @read.22(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.22(i32) #0 +declare i32 @close.23(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.23(ptr, ptr, i64) #0 +declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.24(ptr, ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.25(ptr) #0 +declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.26(ptr, ptr, i64) #0 +declare i64 @GPA.init.27(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.27(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.28(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.29(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.30(ptr, ptr) #0 +declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.31(ptr, ptr) #0 +declare void @Arena.reset.32(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.32(ptr, ptr, i64) #0 +declare void @Arena.deinit.33(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.33(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.init.34(ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.35(ptr, ptr) #0 +declare ptr @BufAlloc.init.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.36(ptr, ptr, i64) #0 +declare void @BufAlloc.reset.37(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.37(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.38(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.39(ptr, ptr) #0 +declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.40(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.41(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report.42(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.42(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @open.43(ptr, i32, ...) #0 +declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.44(i32) #0 +declare i32 @open.45(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @read.45(i32, ptr, i64) #0 +declare i32 @close.46(i32) #0 ; Function Attrs: nounwind -declare i64 @lseek.46(i32, i64, i32) #0 +declare i64 @read.47(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @unlink.47(ptr) #0 +declare i64 @lseek.48(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @rmdir.48(ptr) #0 +declare i32 @unlink.49(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.49(ptr, i32) #0 +declare i32 @rmdir.50(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.50(ptr, i32) #0 +declare i32 @mkdir.51(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.51(ptr, i32) #0 +declare i32 @access.52(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.52(ptr, ptr) #0 +declare i32 @chmod.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.53(ptr, ptr) #0 +declare i32 @rename.54(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.54(ptr, ptr) #0 +declare i1 @File.is_valid.55(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.55(ptr, ptr, ptr) #0 +declare i1 @File.close.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.56(ptr, ptr, ptr) #0 +declare i64 @File.read.57(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.57(ptr, ptr, i64, i64) #0 +declare i64 @File.write.58(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.58(ptr, i64) #0 +declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.59(ptr, ptr, i64) #0 +declare i32 @mode_to_flags.60(ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.60(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i64 @open_file.61(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.61(ptr, ptr, ptr) #0 +declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.62(ptr, ptr, ptr) #0 +declare i1 @write_file.63(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.63(ptr, ptr) #0 +declare i1 @append_file.64(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.64(ptr, ptr) #0 +declare i1 @exists.65(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.65(ptr, ptr) #0 +declare i1 @delete_file.66(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.66(ptr, ptr) #0 +declare i1 @delete_dir.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.67(ptr, ptr, i32) #0 +declare i1 @create_dir.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.68(ptr, ptr, ptr) #0 +declare i1 @set_mode.69(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.69(ptr, ptr) #0 +declare i1 @move.70(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.70(ptr, ptr, ptr) #0 +declare i1 @create_dir_all.71(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.71(ptr, ptr) #0 +declare i1 @copy_file.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.72(ptr, ptr) #0 +declare ptr @basename.73(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @dirname.74(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -724,64 +733,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.73(ptr, i32) #0 +declare ptr @spaces.75(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.74() #0 +declare i32 @sx_trace_len.76() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.75() #0 +declare i32 @sx_trace_truncated.77() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.76(i32) #0 +declare i64 @sx_trace_frame_at.78(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.77(ptr) #0 +declare ptr @to_string.79(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.78(ptr) #0 +declare void @print_current.80(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.79(ptr) #0 +declare void @print_interpreter_frames.81(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.80(ptr, ptr) #0 +declare ptr @popen.82(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.81(ptr) #0 +declare i32 @pclose.83(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.82(ptr, i64, i64, ptr) #0 +declare i64 @fread.84(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.83(ptr) #0 +declare i32 @feof.85(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.84(ptr) #0 +declare ptr @getenv.86(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.85(ptr) #0 +declare i64 @strlen.87(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.86(ptr) #0 +declare i32 @system.88(ptr) #0 ; Function Attrs: nounwind -declare void @run.87(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.88(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.89(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.90(i32) #0 +declare void @_exit.92(i32) #0 ; Function Attrs: nounwind -declare void @exit.91(ptr, i8, ptr) #0 +declare void @exit.93(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.92(ptr, i1, ptr, ptr) #0 +declare void @assert.94(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -811,97 +820,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.93(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 +declare void @parse.95(ptr sret({ { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, i32 }), ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.94(ptr, i32, ...) #0 +declare i32 @open.96(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.95(i32) #0 +declare i32 @close.97(i32) #0 ; Function Attrs: nounwind -declare i64 @read.96(i32, ptr, i64) #0 +declare i64 @read.98(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.97(i32, i64, i32) #0 +declare i64 @lseek.99(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.98(ptr) #0 +declare i32 @unlink.100(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.99(ptr) #0 +declare i32 @rmdir.101(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.100(ptr, i32) #0 +declare i32 @mkdir.102(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.101(ptr, i32) #0 +declare i32 @access.103(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.102(ptr, i32) #0 +declare i32 @chmod.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.103(ptr, ptr) #0 +declare i32 @rename.105(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.104(ptr, ptr) #0 +declare i1 @File.is_valid.106(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.105(ptr, ptr) #0 +declare i1 @File.close.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.106(ptr, ptr, ptr) #0 +declare i64 @File.read.108(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.107(ptr, ptr, ptr) #0 +declare i64 @File.write.109(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.108(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.109(ptr, i64) #0 +declare i32 @mode_to_flags.111(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.110(ptr, ptr, i64) #0 +declare i64 @open_file.112(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.111(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.112(ptr, ptr, ptr) #0 +declare i1 @write_file.114(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.113(ptr, ptr, ptr) #0 +declare i1 @append_file.115(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.114(ptr, ptr) #0 +declare i1 @exists.116(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.115(ptr, ptr) #0 +declare i1 @delete_file.117(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.116(ptr, ptr) #0 +declare i1 @delete_dir.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.117(ptr, ptr) #0 +declare i1 @create_dir.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.118(ptr, ptr, i32) #0 +declare i1 @set_mode.120(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.119(ptr, ptr, ptr) #0 +declare i1 @move.121(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.120(ptr, ptr) #0 +declare i1 @create_dir_all.122(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.121(ptr, ptr, ptr) #0 +declare i1 @copy_file.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.122(ptr, ptr) #0 +declare ptr @basename.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.123(ptr, ptr) #0 +declare ptr @dirname.125(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -940,118 +949,118 @@ declare [64 x i8] @sha256_hex(ptr, ptr) #0 declare void @sha256_file(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.124(ptr, i1) #0 +declare void @assert.126(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.125(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.126(i64, ptr) #0 +declare void @BuildOptions.add_framework.128(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.127(i64, ptr) #0 +declare void @BuildOptions.set_output_path.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.128(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.129(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.130(i64) #0 +declare i64 @BuildOptions.asset_dir_count.132(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.131(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.132(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.133(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.134(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.135(i64) #0 +declare ptr @BuildOptions.binary_path.137(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.136(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.137(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.138(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.139(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.140(i64) #0 +declare ptr @BuildOptions.bundle_path.142(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.141(i64) #0 +declare ptr @BuildOptions.bundle_id.143(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.142(i64) #0 +declare ptr @BuildOptions.codesign_identity.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.143(i64) #0 +declare ptr @BuildOptions.provisioning_profile.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.144(i64) #0 +declare ptr @BuildOptions.target_triple.146(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.145(i64) #0 +declare i1 @BuildOptions.is_macos.147(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.146(i64) #0 +declare i1 @BuildOptions.is_ios.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.147(i64) #0 +declare i1 @BuildOptions.is_ios_device.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.148(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.149(i64) #0 +declare i1 @BuildOptions.is_android.151(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.150(i64) #0 +declare i64 @BuildOptions.framework_count.152(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.151(i64, i64) #0 +declare ptr @BuildOptions.framework_at.153(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.152(i64) #0 +declare i64 @BuildOptions.framework_path_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.154(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.155(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.156(i64) #0 +declare ptr @BuildOptions.manifest_path.158(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.157(i64) #0 +declare ptr @BuildOptions.keystore_path.159(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.158(i64) #0 +declare i64 @BuildOptions.jni_main_count.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.159(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.160(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.161() #0 +declare i64 @build_options.163() #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -1091,7 +1100,7 @@ entry: %jni.parent.cls = call ptr %jni.FindClass(ptr %load, ptr @jni.parent.path) %4 = getelementptr inbounds ptr, ptr %jni.ifs, i32 33 %jni.GetMethodID = load ptr, ptr %4, align 8 - %jni.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.parent.cls, ptr @str, ptr @str.162) + %jni.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.parent.cls, ptr @str, ptr @str.164) %jni.parent.cls.slot = alloca ptr, align 8 store ptr %jni.parent.cls, ptr %jni.parent.cls.slot, align 8 %5 = getelementptr inbounds ptr, ptr %jni.ifs, i32 91 @@ -1107,7 +1116,7 @@ entry: %jni.ctor.cls = call ptr %jni.FindClass9(ptr %load, ptr @jni.ctor.path) %7 = getelementptr inbounds ptr, ptr %jni.ifs8, i32 33 %jni.GetMethodID10 = load ptr, ptr %7, align 8 - %jni.ctor.mid = call ptr %jni.GetMethodID10(ptr %load, ptr %jni.ctor.cls, ptr @str.163, ptr @str.164) + %jni.ctor.mid = call ptr %jni.GetMethodID10(ptr %load, ptr %jni.ctor.cls, ptr @str.165, ptr @str.166) %8 = getelementptr inbounds ptr, ptr %jni.ifs8, i32 28 %jni.NewObject = load ptr, ptr %8, align 8 %jni.new.obj = call ptr %jni.NewObject(ptr %load, ptr %jni.ctor.cls, ptr %jni.ctor.mid, ptr %loadN) diff --git a/issues/0119-ufcs-generic-free-function-unresolved.md b/issues/0119-ufcs-generic-free-function-unresolved.md index 690a35e..58173e4 100644 --- a/issues/0119-ufcs-generic-free-function-unresolved.md +++ b/issues/0119-ufcs-generic-free-function-unresolved.md @@ -1,5 +1,21 @@ # 0119 — UFCS dot-call on a GENERIC free function: "unresolved ''" +> **RESOLVED — not a bug** (2026-06-11, Agra language ruling, same +> session). Dot-form UFCS on generic free functions is NOT the language +> contract: UFCS free-function dot-dispatch is the annotated mechanism +> (`name :: ufcs target;`, concrete targets), and the FLUENT spelling +> for free functions is the pipe operator — `xs |> first_of()` desugars +> at parse time to `first_of(xs)`, which dispatches generics through +> the normal monomorphization machinery (verified: +> `context.allocator |> create(Session)` works). specs.md §UFCS +> corrected (it overstated "works with ... generic functions" for the +> dot form). No compiler change. MEM Phase 2.2 unblocked — helpers +> shipped as free functions with the direct + `|>` contract +> (examples/0838-memory-helpers.sx pins both spellings). +> Residual corner (not contracted, unfiled): a `ufcs` ALIAS naming a +> generic target also doesn't dot-dispatch; file separately if ever +> wanted. + ## Symptom `obj.func(args)` where `func` is a generic free function (any `$T` in its diff --git a/library/modules/std.sx b/library/modules/std.sx index 798141e..f529572 100644 --- a/library/modules/std.sx +++ b/library/modules/std.sx @@ -6,14 +6,15 @@ out :: (str: string) -> void #builtin; size_of :: ($T: Type) -> s64 #builtin; align_of :: ($T: Type) -> s64 #builtin; // Low-level libc bindings, used by allocator implementations to avoid -// recursing through `context.allocator`. +// recursing through `context.allocator`. The bare `malloc`/`free` +// spellings are NOT declared: the Allocator protocol + the std/mem.sx +// helpers are the allocation surface (`free` is the typed slice helper +// there). Raw libc escape hatch: `libc_malloc` / `libc_free`. libc_malloc :: (size: s64) -> *void #foreign libc "malloc"; libc_free :: (ptr: *void) -> void #foreign libc "free"; -malloc :: (size: s64) -> *void #foreign libc "malloc"; memcpy :: (dst: *void, src: *void, size: s64) -> *void #foreign libc "memcpy"; memset :: (dst: *void, val: s64, size: s64) -> void #foreign libc "memset"; -free :: (ptr: *void) -> void #foreign libc "free"; type_of :: (val: $T) -> Type #builtin; type_name :: ($T: Type) -> string #builtin; field_count :: ($T: Type) -> s64 #builtin; diff --git a/library/modules/std/mem.sx b/library/modules/std/mem.sx index 2e2d3f0..5dfbe30 100644 --- a/library/modules/std/mem.sx +++ b/library/modules/std/mem.sx @@ -1,5 +1,85 @@ #import "modules/std.sx"; +// --- Typed allocation helpers --- +// +// The user-facing allocation surface over the Allocator protocol's +// bytes-level primitives (`alloc_bytes` / `dealloc_bytes`). Free +// functions — call directly or fluently via the pipe operator: +// +// s := context.allocator |> create(Session); +// s.* = Session.{}; // no zero-init (Zig-aligned) +// defer context.allocator |> destroy(s); +// +// moves := context.allocator |> alloc(Move, 64); +// defer context.allocator |> free(moves); +// +// copied := bytes |> clone(context.allocator); +// +// Bodies are complete for the 2-method protocol era: `mem_realloc` is +// alloc+copy+dealloc (the only shape without resize/remap primitives), +// and `align` is accepted for signature stability — alignment-aware +// allocation lands with the protocol expansion. + +// Allocate one T. Contents are UNINITIALISED — assign before reading. +create :: (a: Allocator, $T: Type) -> *T { + xx a.alloc_bytes(size_of(T)) +} + +// Free a *T obtained from `create`. +destroy :: (a: Allocator, ptr: *$T) { + a.dealloc_bytes(xx ptr); +} + +// Allocate a []T of `count` elements. Contents are UNINITIALISED. +alloc :: (a: Allocator, $T: Type, count: s64) -> []T { + raw := a.alloc_bytes(count * size_of(T)); + s : []T = ---; + s.ptr = xx raw; + s.len = count; + s +} + +// Free a []T obtained from `alloc` / `clone` / `resize`. +free :: (a: Allocator, slice: []$T) { + a.dealloc_bytes(xx slice.ptr); +} + +// Copy a slice into fresh storage owned by `a`. +clone :: (src: []$T, a: Allocator) -> []T { + raw := a.alloc_bytes(src.len * size_of(T)); + memcpy(raw, xx src.ptr, src.len * size_of(T)); + s : []T = ---; + s.ptr = xx raw; + s.len = src.len; + s +} + +// Reallocate a slice to `new_count` elements: fresh storage, contents +// copied up to min(len, new_count), old backing freed. The returned +// slice replaces the operand — the old slice is dangling after this. +resize :: (slice: []$T, a: Allocator, new_count: s64) -> []T { + raw := a.alloc_bytes(new_count * size_of(T)); + n := if slice.len < new_count then slice.len else new_count; + memcpy(raw, xx slice.ptr, n * size_of(T)); + a.dealloc_bytes(xx slice.ptr); + s : []T = ---; + s.ptr = xx raw; + s.len = new_count; + s +} + +// Bytes-level realloc. 2-method era: alloc + copy(min(old,new)) + +// dealloc — there is no in-place grow primitive to try yet, and +// `align` beyond the heap's natural 8 is not honored until the +// protocol carries alignment. +mem_realloc :: (a: Allocator, ptr: *void, old: s64, new: s64, align: s64) -> *void { + raw := a.alloc_bytes(new); + n := if old < new then old else new; + memcpy(raw, ptr, n); + a.dealloc_bytes(ptr); + raw +} + // --- CAllocator: stateless allocator that delegates directly to libc --- // // Zero-sized struct. Used as the default `context.allocator` at program diff --git a/specs.md b/specs.md index 8a93605..d0663dd 100644 --- a/specs.md +++ b/specs.md @@ -2291,7 +2291,19 @@ p := Point.{3, 4}; print("{}\n", p.point_sum()); // calls point_sum(p) → 7 ``` -UFCS works with pointer receivers (auto-deref applies) and generic functions. If the field name exists as both a struct field and a free function, the struct field takes priority. +UFCS works with pointer receivers (auto-deref applies). Generic struct +*methods* dispatch via dot; a generic **free function** (any `$T` in its +signature) is NOT dot-rewritten — call it directly or fluently via the +pipe operator, which desugars at parse time to the direct call: + +```sx +first_of :: (xs: []$T) -> T { xs[0] } + +first_of(xs); // direct +xs |> first_of(); // fluent — desugars to first_of(xs) +``` + +If the field name exists as both a struct field and a free function, the struct field takes priority. #### UFCS Aliases The `ufcs` keyword creates a name alias for a function, decoupling the method name from the function name: